21

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

W是一个数据表。我该如何setkey打电话?Wwhich_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钥匙不在那里。

任何指针?

4

1 回答 1

23

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
于 2013-05-02T20:47:29.517 回答