1

我有一个数据集,其中包含个人随着时间的推移在哪里工作的信息。更具体地说,我有关于个人在给定工作场所工作的时间间隔的信息。

library('tidyverse')
library('lubridate')

# individual A
a_id <- c(rep('A',1))
a_start <- c(201201)
a_end <- c(201212)
a_workplace <-c(1)

# individual B
b_id <- c(rep('B',2))
b_start <- c(201201, 201207)
b_end <- c(201206, 201211)
b_workplace <-c(1, 2)

# individual C
c_id <- c(rep('C',2))
c_start <- c(201201, 201202)
c_end <- c(201204, 201206)
c_workplace <-c(1, 2)
  
# individual D
d_id <- c(rep('D',1))
d_start <- c(201201)
d_end <- c(201201)
d_workplace <-c(1)

# final data frame
id <- c(a_id, b_id, c_id, d_id)
start <- c(a_start, b_start, c_start, d_start)
end <- c(a_end, b_end, c_end, d_end)
workplace <- as.factor(c(a_workplace, b_workplace, c_workplace, d_workplace))
mydata <- data.frame(id, start, end, workplace)

mydata_ym <- mydata %>%
  mutate(ymd_start = as.Date(paste0(start, "01"), format = "%Y%m%d"),
         ymd_end0 = as.Date(paste0(end, "01"), format = "%Y%m%d"),
         day_end = as.numeric(format(ymd_end0 + months(1) - days(1), format = "%d")),
         ymd_end = as.Date(paste0(end, day_end), format = "%Y%m%d")) %>%
  select(-ymd_end0, -day_end)

我想要一个可以看到每个人在每个工作场所工作多长时间以及他们如何四处走动的模式。我尝试绘制一个geom_segment,因为我有每个地方的个人作品的开始和结束日期的信息。此外,由于同一个人可能在同一个月内在多个地方工作,所以我想position_dodge在同一工作时间的不同工作场所重叠时使其可见。这是在这篇文章中提出的:Ggplot (geom_line) with overlays

ggplot(mydata_ym) +
  geom_segment(aes(x = id, xend = id, y = ymd_start, yend = ymd_end), 
               position = position_dodge(width = 0.1), size = 2) +
  scale_x_discrete(limits = rev) +
  coord_flip() +
  theme(panel.background  = element_rect(fill = "grey97")) +
  labs(y = "time", title = "Work affiliation")

我遇到的问题是:(i)position_dodge似乎没有工作,(ii)我不知道为什么所有的段都被涂成黑色。我希望每个工作场所都会出现不同的颜色和传奇。

4

1 回答 1

1

如果您colour = workplaceaes()映射中包含geom_segment颜色和图例以及一些闪避,但它不能正常工作(它看起来position_dodge只适用于x而不是xend......?这似乎是一个错误,或者至少是一个“不合理“,在position_dodge...

但是,用geom_segment适当的使用替换geom_linerange似乎确实有效:

ggplot(mydata_ym) +
  geom_linerange(aes(x = id, ymin = ymd_start, ymax = ymd_end, colour = workplace),
               position = position_dodge(width = 0.1), size = 2) +
  scale_x_discrete(limits = rev) +
  coord_flip()

(省略了一些切向组件)。

此处先前记录了一种类似的方法-处理colour=映射后,您的问题几乎是重复的...

于 2021-10-17T19:16:16.953 回答