我在 R 中有一个来自不同部门的约会数据集。
> dput(head(Data.2016))
structure(list(NUMMER = c(361626L, 411992L, 2752868L, 6592340L, 9017183L, 451010L),
DEPARTMENT= structure(c(3L, 3L, 3L, 3L, 3L, 3L), .Label = c("DEA", "DIE",
"IAL", "IEN", "IGH", "IHM", "ILN", "INE", "INF", "INT"), class = "factor"),
TYPE_APPOINTMENT = structure(c(3L, 3L, 3L, 3L, 3L, 2L), .Label = c("BZ", "E", "H",
"NK", "TF", "VP", "VW"), class = "factor"),
WEEKDAY = structure(c(5L, 6L, 6L, 6L, 6L, 2L), .Label = c("Sun", "Mon", "Tues",
"Wed", "Thurs", "Fri", "Sat"), class = c("ordered", "factor")),
.Names = c("NUMMER", "DEPARTMENT", "TYPE_APPOINTMENT", "WEEKDAY"), row.names = c(1L, 2L,
4L, 5L, 6L, 7L), class = "data.frame")
我希望为一周中的每一天构建一个区分约会类型和部门的图。我使用以下代码来执行此操作:
library(ggplot2)
ggplot(Data.2016,
aes(x=Data.2016$WEEKDAY,
fill=Data.2016$TYPE_APPOINTMENT)) +
geom_bar() +
facet_grid(~DEPARTMENT)+
theme(legend.title=element_blank()) +
labs(x = "Days of the week")
这导致以下情节: 约会
这是关于我的期望和我需要的(忽略 x 轴的丑陋)。
然而,稍微调查了一下剧情后,我发现结果并不正确。部门 DIE 不能有任何“E”或“H”,但在上面的情节中它以某种方式存在。其实当我只选择DIE的时候,使用下面的代码
ggplot(Data.2016[which(Data.2016$DEPARTMENT == "DIE"),],
aes(x=Data.2016$WEEKDAY,
fill=Data.2016$TYPE_APPOINTMENT)) +
geom_bar() +
theme(legend.title=element_blank()) +
labs(x = "Days of the week")
结果是Appointments DIE,这是正确的。
我究竟做错了什么?或者这是其他 R 用户知道的故障?