ggplot条形图与面依赖类别的顺序

前端之家收集整理的这篇文章主要介绍了ggplot条形图与面依赖类别的顺序前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我已经看到许多问题(通常与 Order Bars in ggplot2 bar graph相关),关于如何(重新)在条形图中排序类别.

我所追求的只是一个不同的触摸,但是我还没有找到一个很好的方法:我有一个多面的条形图,我想根据另一个变量来独立地为每个方面排列x轴在我的情况下,该变量只是y值本身,即我只是希望在每个方面增加长度的条).

简单的例子,例如. Order Bars in ggplot2 bar graph

df <- data.frame(name=c('foo','bar','foo','bar'),period=c('old','old','recent','recent'),val=c(1.23,2.17,4.15,3.65))
p = ggplot(data = df,aes(x = reorder(name,val),y = val))
p = p + geom_bar(stat='identity')
p = p + facet_grid(~period)
p

我们得到如下:

而我想要的是:

好的,所有的哲学都放在一边,如果有人有兴趣,这里是一个丑陋的做法.这个想法是使用不同的标签(认为粘贴(句点,名称),除了将句点替换为0空格,1空格等,以使它们不显示).我需要这个情节,我不想安排grobs等,因为我可能想分享一个常见的传说等.

以前给出的原子示例是:

df <- data.frame(name=c('foo',3.65),stringsAsFactors=F)
df$n = as.numeric(factor(df$period))
df = ddply(df,.(period,name),transform,x=paste(c(rep(' ',n-1),collapse=''))
df$x = factor(df$x,levels=df[order(df$val),'x'])
p = ggplot(data = df,aes(x = x,y = val))
p = p + geom_bar(stat='identity')
p = p + facet_grid(~period,scale='free_x')
p

另一个例子,仍然有点傻,但更接近我的实际用例,将是:

df <- ddply(mpg,.(year,manufacturer),summarize,mixmpg = mean(cty+hwy))
df$manufacturer = as.character(df$manufacturer)
df$n = as.numeric(factor(df$year))
df = ddply(df,levels=df[order(df$mixmpg),y = mixmpg))
p = p + geom_bar(stat='identity')
p = p + facet_grid(~year,scale='free_x')
p = p + theme(axis.text.x=element_text(angle=90,hjust=1,vjust=.5,colour='gray50'))
p

闭上你的眼睛,想想帝国,并尝试享受.

猜你在找的设计模式相关文章