嗨,我已经制作了这个功能,需要一张桌子并为条形图准备标签
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)
由于sep参数对于所有粘贴调用都是相同的,因此您可以组合成一个:
labs <- paste(ft,"\n",round(prop.table(ft)*100,2),"%",sep="")
Run Code Online (Sandbox Code Playgroud)
或者,使用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