如何使用某些列名的字符向量在data.table中选择列?

时间:2015-08-24 14:01:21

标签: r data.table

我正在尝试在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

我刚制作了一个包含disphpwt的向量,并使用该向量在我的data.frame中选择了相应的列。现在让我们从data.frame创建一个data.table对象,并尝试执行相同的操作。

> library(data.table)
> mtcarsDT <- data.table(mtcars)
> mtcarsDT[, myVector]
[1] "disp" "hp"   "wt"  

1 个答案:

答案 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'中有用,可以动态选择列。