如何使用...
lapply(.SD, FUN, ...)
参数的固定特定列
示例
DT <- data.table(id_column = rnorm(10),
x1 = rnorm(10), x2 = rnorm(10), x3 = rnorm(10))
measure_col = paste0("x",1:3)
DT[,lapply(.SD, cov, y=id_column), .SDcols = measure_col]
结果
Error in is.data.frame(y) : object 'id_column' not found
可能的解决方法是
DT[,lapply(.SD, cov, y = DT[,id_column]), .SDcols = measure_col]
x1 x2 x3
1: 0.1703253 -0.2831533 0.3387133
有更好的方法吗?没有通过y=DT[,id_column]
答案 0 :(得分:5)
问题#495现已通过this recent commit解决,我们现在可以做到这一点:
require(data.table) # v1.9.7+
DT <- data.table(id_column = rnorm(10), x1 = rnorm(10), x2 = rnorm(10), x3 = rnorm(10))
measure_col = paste0("x",1:3)
DT[,lapply(.SD, cov, y=id_column), .SDcols = measure_col]
# x1 x2 x3
# 1: -0.03137294 0.1903654 -0.1493648