您的位置:首页 > 其它

【R笔记】R语言利器之ddply

2016-03-23 10:54 218 查看
ddply()函数位于plyr包,用于对data.frame进行分组统计,与tapply有些类似

准备数据

# 使用stringsAsFactors=F来防止data.frame把向量转为factor
apache = data.frame(httpCode=c(200,200,200,404,404,500),
time=c(100,111,210,10,10,500),
api=c('index','index','logout','show','show','index'),
stringsAsFactors=F)

统计每个api的请求数

ddply(apache,.(api),summarize,number=length(api))
api number
1  index      32 logout      13   show      2

统计每个api的各个httpCode的请求数:

a <- ddply(apache,.(api,httpCode),summarize,number=length(api))
api httpCode number
1  index      200      22  index      500      13 logout      200      14   show      404      2

下面这个复杂些,根据上面的统计结果a,统计每个api所占比例

b <- ddply(a,
.(),
.fun=function(x){
transform(x, percentage=with(x,ave(number,api,FUN=sum)/sum(number)))
})
.id    api httpCode number percentage
1 <NA>  index      200      2      0.3332 <NA>  index      500      1      0.1673 <NA> logout      200      1      0.1674 <NA>   show      404      2      0.333

这就是说你可以根据需要写自己的统计函数

用ggplot画api占比图

ggplot(b,aes(x=reorder(api,percentage),y=percentage,fill=factor(httpCode))) +
geom_bar() +
scale_y_continuous(labels = percent_format()) +
coord_flip() +





来源: http://my.oschina.net/enyo/blog/162595?utm_source=tuicool&utm_medium=referral

来自为知笔记(Wiz)
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: