我想开始使用 dplyr 代替 ddply 但我无法了解它的工作原理(我已阅读文档)。
例如,为什么当我尝试 mutate() 时,“group_by”函数不能按预期工作?
看mtcars:
图书馆(汽车)
假设我制作了一个 data.frame,它是 mtcars 的摘要,按“cyl”和“gear”分组:
df1 <- mtcars %.%
group_by(cyl, gear) %.%
summarise(
newvar = sum(wt)
)
然后说我想进一步总结这个数据框。使用 ddply,它会很简单,但是当我尝试使用 dplyr 时,它实际上并不是“分组依据”:
df2 <- df1 %.%
group_by(cyl) %.%
mutate(
newvar2 = newvar + 5
)
仍然产生一个未分组的输出:
cyl gear newvar newvar2
1 6 3 6.675 11.675
2 4 4 19.025 24.025
3 6 4 12.375 17.375
4 6 5 2.770 7.770
5 4 3 2.465 7.465
6 8 3 49.249 54.249
7 4 5 3.653 8.653
8 8 5 6.740 11.740
我在语法上做错了吗?
编辑:
如果我要使用 plyr 和 ddply 执行此操作:
df1 <- ddply(mtcars, .(cyl, gear), summarise, newvar = sum(wt))
然后得到第二个df:
df2 <- ddply(df1, .(cyl), summarise, newvar2 = sum(newvar) + 5)
但是同样的方法,在 summarise() 函数中使用 sum(newvar) + 5 不适用于 dplyr ...