在R中将条形图转换为饼图

时间:2015-02-13 06:01:06

标签: r charts ggplot2 bar-chart pie-chart

我有以下数据和代码:

dd
  grp categ condition value
1   A     X         P     2
2   B     X         P     5
3   A     Y         P     9
4   B     Y         P     6
5   A     X         Q     4
6   B     X         Q     5
7   A     Y         Q     8
8   B     Y         Q     2
> 
> 
dput(dd)
structure(list(grp = structure(c(1L, 2L, 1L, 2L, 1L, 2L, 1L, 
2L), .Label = c("A", "B"), class = "factor"), categ = structure(c(1L, 
1L, 2L, 2L, 1L, 1L, 2L, 2L), .Label = c("X", "Y"), class = "factor"), 
    condition = structure(c(1L, 1L, 1L, 1L, 2L, 2L, 2L, 2L), .Label = c("P", 
    "Q"), class = "factor"), value = c(2, 5, 9, 6, 4, 5, 8, 2
    )), .Names = c("grp", "categ", "condition", "value"), out.attrs = structure(list(
    dim = structure(c(2L, 2L, 2L), .Names = c("grp", "categ", 
    "condition")), dimnames = structure(list(grp = c("grp=A", 
    "grp=B"), categ = c("categ=X", "categ=Y"), condition = c("condition=P", 
    "condition=Q")), .Names = c("grp", "categ", "condition"))), .Names = c("dim", 
"dimnames")), row.names = c(NA, -8L), class = "data.frame")


ggplot(dd, aes(grp,value, fill=condition))+geom_bar(stat='identity')+facet_grid(~categ)

enter image description here

如何将此条形图转换为饼图?我想要4个馅饼,它们的尺寸与这里各个酒吧的高度相对应。我试过跟随,但他们没有工作:

ggplot(dd, aes(grp,value, fill=condition))+geom_bar(stat='identity')+facet_grid(~categ)+coord_polar()
ggplot(dd, aes(grp,value, fill=condition))+geom_bar(stat='identity')+facet_grid(~categ)+coord_polar('y')

我还尝试制作类似于Pie charts in ggplot2 with variable pie sizes的饼图,但我无法管理我的数据。谢谢你的帮助。

2 个答案:

答案 0 :(得分:1)

您希望组和类别都是网格的变量,而不是任何绘图内部。这是两种不同的布局。 X应该是任何单个项目,字符串或其他内容。

ggplot(dd, aes(x=factor(1),y=value,
 fill=condition))+geom_bar(stat='identity')+
 facet_grid(~grp+categ)+coord_polar("x")
ggplot(dd, aes(x=factor(1),y=value,
 fill=condition))+geom_bar(stat='identity')+
 facet_grid(grp~categ)+coord_polar("x")

这里的顶部开口发生了一些奇怪的事,也许只是我的界面。应该让你足够了!

Pie charts side by side

Pie charts in a square

答案 1 :(得分:1)

使用与您发布的链接相同的想法,您可以添加一列size来处理您的数据帧,该数据帧将是每个组的值的总和,并将其用作width参数:

library(dplyr)
dd<-dd %>% group_by(categ,grp) %>% mutate(size=sum(value))
ggplot(dd, aes(x=size/2,y=value,fill=condition,width=size))+geom_bar(position="fill",stat='identity')+facet_grid(grp~categ)+coord_polar("y")

enter image description here