我想使用data.table中的setkey
与预定义列表id
和categories
,但是出现了错误信息:
> setkey(tr_id_cat_dt, id, categories)
Error in setkeyv(x, cols, verbose = verbose) :
some columns are not in the data.table: categories
我希望所有的 id
和 categories
元素都能作为键出现。
这是否可能?
id
和 categories
是值列表,例如:
categories = c(9115L, 9909L, 3203L, 5558L, 4401L, 1703L, 1726L, 3504L, 3509L,
5122L, 5616L, 5619L, 2202L, 2119L, 6202L, 5824L, 799L, 4517L,
7205L, 706L)
dput(head(tr_id_cat_dt))
structure(list(id = c(86246, 86246, 86246, 86246, 86246, 86246
), category = c(706L, 706L, 706L, 706L, 706L, 706L)), .Names = c("id",
"category"), sorted = c("id", "category"), class = c("data.table",
"data.frame"), row.names = c(NA, -6L), .internal.selfref = <pointer: 0x015424a0>)
setkey(tr_id_cat_dt, c("id", "categories"))
能行吗?还是应该用setkeyv(tr_id_cat_dt, c("id", "categories"))
? - David Arenburgdput(head(tr_id_cat_dt))
。categories
是否是 data.table 中的一列? - Rolanddput
输出的结构:你的categories
列实际上被称为category
。 - Scott Ritchie