> library(data.table)
> A <- data.table(x = c(1,1,2,2), y = c(1,2,1,2), v = c(0.1,0.2,0.3,0.4))
> A
x y v
1: 1 1 0.1
2: 1 2 0.2
3: 2 1 0.3
4: 2 2 0.4
> B <- dcast(A, x~y)
Using v as value column: use value.var to override.
> B
x 1 2
1 1 0.1 0.2
2 2 0.3 0.4
显然,我可以使用 reshape2 包的 fx dcast 从长到宽重塑 data.table。但是 data.table 带有一个重载的括号运算符,提供像“by”和“group”这样的参数,这让我想知道是否可以使用它来实现它(到 data.table 特定功能)?
手册中的一个随机示例:
DT[,lapply(.SD,sum),by=x]
这看起来很棒——但我还不完全理解它的用法。
我既没有找到方法也没有找到一个例子,所以也许这是不可能的,也许它甚至不应该是 - 所以,一个明确的“不,不可能,因为......”当然也是一个有效的答案.