我正在ggplot2中绘制堆栈条形图。我的数据集就像,
var1 var2 var3 value
treatment1 group_1 C8.0 0.010056478
treatment2 group_1 C8.0 0.009382918
treatment3 group_2 C8.0 0.003014983
treatment4 group_2 C8.0 0.005349631
treatment5 group_2 C8.0 0.005349631
var1
包含5种治疗,这5种治疗属于var2
中的两组,每种治疗在var3
中有14项测量,其值存储在value
。< / p>
我想制作一个情节来比较这五种治疗方法及其测量结果。
所以我用堆栈条图绘制如下图:
我的代码:
library(ggplot2)
colourCount = length(unique(mydata$var3))
getPalette = colorRampPalette(brewer.pal(14, "YlGnBu")) #get more color from palette
ggplot(data=mydata, aes(x=var1, y=value, fill=var3))+
geom_bar(stat="identity", position="stack", colour="black", width=.2)+
*#geom_errorbar(aes(ymax=var3+se, ymin=var3-se, width=.1))+*
scale_fill_manual(values = getPalette(colourCount))+
scale_y_continuous(expand = c(0, 0))+
mytheme
如何将前两个堆叠列组合在一起,将其他三列组合在一起?因为它们属于var2
中的两个组。
答案 0 :(得分:4)
&#34;重复的问题&#34;上面的评论将引导您得到如下答案:
ggplot(dummydf, aes(var1, value, fill = var3)) +
geom_col(position = "stack") +
facet_grid(~var2, scales = "free_x", space = "free_x") +
theme(panel.spacing = unit(3, "cm"),
strip.text = element_text(size = 12, family = "mono"))
这个解决方案有时很棒!优点是:
例如:
dummydf %>%
bind_rows(data_frame(var1 = "trt99")) %>%
ggplot(aes(var1, value, fill = var3)) +
geom_col(position = "stack") +
scale_x_discrete(limits = c("trt1", "trt2", "trt99", "trt3", "trt4", "trt5"),
breaks = c("trt1", "trt2", NA, "trt3", "trt4", "trt5"),
labels = c("trt1", "trt2", "", "trt3", "trt4", "trt5"))
此方法的主要缺点:
所以这是另一种方法:
NA
此解决方案有其自身的缺点,主要是您只能以有限的方式自定义空间。你可以创建一个&#34; false&#34; bar等于您已经通过向限制,中断和标签添加其他错误级别而获得的条形宽度的整数倍。但是你不能创造一个只有半个条宽的空间。
您可以在虚假栏空间中提供其他信息:
""
和breaks
或类似内容替换labels
和trt99
中的"<-group1 | group2->"
和{{1}}。答案 1 :(得分:0)
我认为您只需要在数据集中创建一个新列,标记所有内容&#34; treatment3&#34;并且&#34;不是治疗3&#34;。我使用了dplyr
包:
df1 = dplyr::mutate(mydata,
var4 = ifelse(var1 == "treatment3", "treatment3", "not treatmeant3"))