Minimal örnek:
dt <- data.table(a=c(1,2,3),b=c(4,5,6))
Böyle görünüyor :
> dt
a b
1: 1 4
2: 2 5
3: 3 6
Bir sütunun bulunduğu sütunu indekslemek istediğimi varsayalım 6
değer, bu oyuncak örneğinde sütunu bildiğimiz için kolaydır:
> dt[,.(b)]
b
1: 4
2: 5
3: 6
Eğer şimdi ne dt
birkaç bin sütun vardı ve nerede olduğunu bilemeyiz. 6
yalanlar.
Bunu denedim :
> dt[,.SD==6]
a b
[1,] FALSE FALSE
[2,] FALSE FALSE
[3,] FALSE TRUE
ve bu:
> dt[,lapply(.SD,`==`,6)]
a b
1: FALSE FALSE
2: FALSE FALSE
3: FALSE TRUE
ve ayrıca bu:
> dt[,lapply(.SD,function(x) any(x==6))]
a b
1: FALSE TRUE
Ama orijinal sütunu geri alamıyorum:
b
1: 4
2: 5
3: 6