在R图中标注百分比

Lib*_*ici 4 r

嗨,我已经制作了这个功能,需要一张桌子并为条形图准备标签

prepare_labels <- function(ft){
  labs <- ft
  labs <- paste(labs, "\n", sep="")
  labs <- paste(labs, round(prop.table(ft)*100,2), sep="")
  labs <- paste(labs, "%", sep="")
  return(labs)
}
Run Code Online (Sandbox Code Playgroud)

它实际上工作正常,但有没有更好的方法来编写该功能,上面的代码看起来很丑,我想编写漂亮的代码:-)

例如:

ft <- table(mydata$phone_partner_products)
prepare_labels(ft)
[1] "3752\n34.09%" "226\n2.05%"   "2907\n26.41%" "1404\n12.76%" "1653\n15.02%"
[6] "1065\n9.68%" 
Run Code Online (Sandbox Code Playgroud)

Jam*_*mes 5

由于sep参数对于所有粘贴调用都是相同的,因此您可以组合成一个:

labs <- paste(ft,"\n",round(prop.table(ft)*100,2),"%",sep="")
Run Code Online (Sandbox Code Playgroud)


aL3*_*3xa 5

或者,使用ggplot2:

ggplot(mtcars, aes(factor(cyl))) + geom_bar() + stat_bin(aes(label = paste(prop.table(..count..) * 100, "%", sep = "")), vjust = -0.2, geom = "text", position = "identity")
Run Code Online (Sandbox Code Playgroud)

得到这样的东西:

alt text http://img532.imageshack.us/img532/8201/barplotwpct.png