data.table:使用带有列名变量的setkey

时间:2013-05-02 20:17:22

标签: r data.table

我有一个变量名保存在字符串变量which_id中。

W是一个data.table。如何使用setkeyW上致电which_id

这就是我试过的

 > eval( paste( 'setkey(W,' , which_id , ')' ) )
[1] "setkey(W, customer_id_A )"

但是,对tables()的调用显示customer_id_A密钥没有显示。

 > evalq( paste( 'setkey(W,' , which_id , ')' ) )
[1] "setkey(W, customer_id_A )"

customer_id_A密钥仍未执行。

 > setkeyv( W , cols=which_id )

 > setkeyv( W , cols=c( which_id ) )

- >同样的事情,customer_id_A键不存在。

任何指针?

1 个答案:

答案 0 :(得分:21)

setkeyv应该有效。这是一个可重复的例子:

library(data.table)
W <- data.table(customer_id_A = 1:2)
which_id <- "customer_id_A"
setkeyv(W, which_id)
tables()
##      NAME NROW MB COLS          KEY          
## [1,] W       2 1  customer_id_A customer_id_A
## Total: 1MB
相关问题