この質問は、この前の質問のフォローアップです。
ID のベクトルがありsampleIDs
ます。また、rec_data_table
入札によってキーが
付けられA_IDs.list
、各要素が aID のコレクション (ベクトル) である列を含む data.table があります。
sampleIDs
および
For each を含む 2 番目の data.table を作成したいと思います。
その aID が列に表示されるaID
すべての bID の対応するベクトルがあります。A_IDs.list
例:
> rec_data_table
bid counts names_list A_IDs.list
1: 301 21 C,E 3,NA
2: 302 21 E NA
3: 303 5 H,E,G 8,NA,7
4: 304 10 H,D 8,4
5: 305 3 E NA
6: 306 5 G 7
7: 307 6 B,C 2,3
> sampleIDs
[1] 3 4 8
AB.dt <- data.table(aID=sampleIDs, key="aID")
# unkown step
AB.dt[ , bIDs := ???? ]
# desired result:
> AB.dt
aid bIDs
1: 3 301,307
2: 4 304
3: 8 303,304
AB.dt[]
通話中にいくつかの異なる回線を試しました。私が得ることができた最も近いものは
rec_data_table[sapply(A_IDs.list, function(lst) aID %in% lst), bID]
これにより、指定された に対して望ましい結果が得られaID
、ラップ
オーバーsampleIDs
してベクトルのリストを作成し、望ましい結果を構築できます。
ただし、これを達成するには、より「data.tableに適した」方法が必要だと思います。任意の提案をいただければ幸いです。
#--------------------------------------------------#
# SAMPLE DATA #
library(data.table)
set.seed(101)
rows <- size <- 7
varyingLengths <- c(sample(1:3, rows, TRUE))
A <- lapply(varyingLengths, function(n) sample(LETTERS[1:8], n))
counts <- round(abs(rnorm(size)*12))
rec_data_table <- data.table(bID=300+(1:size), counts=counts, names_list=A, key="bID")
A_ids.DT <- data.table(name=LETTERS[c(1:4,6:8,10:11)], id=c(1:4,6:8,10:11), key="name")
rec_data_table[, A_IDs.list := sapply(names_list, function(n) c(A_ids.DT[n, id]$id))]
sampleIDs <- c(3, 4, 8)