繁体   English   中英

r data.table 以列名作为变量的行子集

[英]r data.table row subset with column name as a variable

我们先在r中创建一个简单的data.table。

dt=data.table(x1=1:5,
           x2=11:21)

如果我们想用行的条件对 data.table 进行子集化,我们可以简单地做,例如

dt[x1==1]

现在我的问题是:如果列名是一个变量怎么办? 我试过:

var="x1"
dt[eval(var)==1,]

但是这段代码不起作用。

eval适用于以下示例:如果我们想按名称(即变量)获取某些列。

dt[x1==1,eval(var),with=F]

我猜你正在寻找get

library(data.table)

DT <- data.table(x1=1:11, x2=11:21)
var <- "x1"
DT[get(var)==1,]

.SD选项

 DT[DT[, .SD[[var]] ==1]]
   x1 x2
1:  1 11

给出与接受的答案相同的 output

 DT[get(var)==1,]
   x1 x2
1:  1 11

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM