我正在尝试在data.table中选择那些名称出现在我的角色向量中的列。该操作在纯data.frame中工作,但不在data.table中工作。这是一个可重复的例子。
> names(mtcars)
[1] "mpg" "cyl" "disp" "hp" "drat" "wt" "qsec" "vs" "am" "gear"
[11] "carb"
> myVector <- c('disp', 'hp', 'wt')
> head(mtcars[, myVector])
disp hp wt
Mazda RX4 160 110 2.620
Mazda RX4 Wag 160 110 2.875
Datsun 710 108 93 2.320
Hornet 4 Drive 258 110 3.215
Hornet Sportabout 360 175 3.440
Valiant 225 105 3.460
我刚制作了一个包含disp
,hp
和wt
的向量,并使用该向量在我的data.frame中选择了相应的列。现在让我们从data.frame创建一个data.table对象,并尝试执行相同的操作。
> library(data.table)
> mtcarsDT <- data.table(mtcars)
> mtcarsDT[, myVector]
[1] "disp" "hp" "wt"
答案 0 :(得分:35)
我们可以使用with=FALSE
执行与data.frame
mtcarsDT[, myVector, with=FALSE]
根据?data.table
with:默认情况下,'with = TRUE'和'j'在帧内进行评估 'x';列名可以用作变量。什么时候 'with = FALSE''j'是列名的字符向量或a 要选择的列位置的数字向量,以及值 返回始终是'data.table'。通常是'with = FALSE' 在'data.table'中有用,可以动态选择列。