ggplot2 条形图的多个子组 [英] ggplot2 multiple sub groups of a bar chart
问题描述
我正在尝试生成具有多个因素分组的条形图.我正在尝试创建的 excel 示例,按品种和灌溉处理分组:
I am trying to produce a bar graph that has multiple groupings of factors. An example from excel of what I am attempting to create, subgrouped by Variety and Irrigation treatment:
我知道我可以使用 facet_wrap()
生成多个图表,但我想为多年相似数据的同一类型数据生成多个图表.我在这个例子中使用的数据的一个例子:
I know I could produce multiple graphs using facet_wrap()
, but I would like to produce multiple graphs for this same type of data for multiple years of similar data. An example of the data I used in this example:
Year Trt Variety geno yield SE
2010-2011 Irr Variety.2 1 6807 647
2010-2011 Irr Variety.2 2 5901 761
2010-2011 Irr Variety.1 1 6330 731
2010-2011 Irr Variety.1 2 5090 421
2010-2011 Dry Variety.2 1 3953 643
2010-2011 Dry Variety.2 2 3438 683
2010-2011 Dry Variety.1 1 3815 605
2010-2011 Dry Variety.1 2 3326 584
有没有办法在 ggplot2 中创建多个分组?我已经搜索了很长时间,但还没有看到类似上面示例图的示例.
Is there a way to create multiple groupings in ggplot2? I have searched for quite some time and have yet to see an example of something like the example graph above.
感谢您的帮助!
推荐答案
这可能是一个开始.
dodge <- position_dodge(width = 0.9)
ggplot(df, aes(x = interaction(Variety, Trt), y = yield, fill = factor(geno))) +
geom_bar(stat = "identity", position = position_dodge()) +
geom_errorbar(aes(ymax = yield + SE, ymin = yield - SE), position = dodge, width = 0.2)
更新:x 轴的标签
我已添加:coord_cartesian
,设置y轴的下限,主要是下限,避免轴默认展开.annotate
,添加需要的标签.我已经对 x
位置进行了硬编码,在这个相当简单的示例中我认为这没问题.theme_classic
,去除灰色背景和网格.theme
,增加下图边距为两行标签留出空间,删除默认标签.
最后一组代码:因为文本是在 x 轴下方添加的,它消失"在绘图区域之外,我们需要删除剪裁".就这样!
Update: labelling of x axis
I have added:
coord_cartesian
, to set limits of y axis, mainly the lower limit to avoid the default expansion of the axis.
annotate
, to add the desired labels. I have hard-coded the x
positions, which I find OK in this fairly simple example.
theme_classic
, to remove the gray background and the grid.
theme
, increase lower plot margin to have room for the two-row label, remove default labels.
Last set of code: Because the text is added below the x-axis, it 'disappears' outside the plot area, and we need to remove the 'clipping'. That's it!
library(grid)
g1 <- ggplot(data = df, aes(x = interaction(Variety, Trt), y = yield, fill = factor(geno))) +
geom_bar(stat = "identity", position = position_dodge()) +
geom_errorbar(aes(ymax = yield + SE, ymin = yield - SE), position = dodge, width = 0.2) +
coord_cartesian(ylim = c(0, 7500)) +
annotate("text", x = 1:4, y = - 400,
label = rep(c("Variety 1", "Variety 2"), 2)) +
annotate("text", c(1.5, 3.5), y = - 800, label = c("Irrigated", "Dry")) +
theme_classic() +
theme(plot.margin = unit(c(1, 1, 4, 1), "lines"),
axis.title.x = element_blank(),
axis.text.x = element_blank())
# remove clipping of x axis labels
g2 <- ggplot_gtable(ggplot_build(g1))
g2$layout$clip[g2$layout$name == "panel"] <- "off"
grid.draw(g2)
这篇关于ggplot2 条形图的多个子组的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!