Esempio minimo:
dt <- data.table(a=c(1,2,3),b=c(4,5,6))
Che sembra che:
> dt
a b
1: 1 4
2: 2 5
3: 3 6
Supponiamo che io voglia indice di colonna in cui c'è un 6
valore, in questo giocattolo esempio è facile poiché sappiamo che la colonna:
> dt[,.(b)]
b
1: 4
2: 5
3: 6
Ora, cosa succede se questo dt
aveva diverse migliaia di colonne e non so dove l' 6
si trova.
Ho provato in questo modo:
> dt[,.SD==6]
a b
[1,] FALSE FALSE
[2,] FALSE FALSE
[3,] FALSE TRUE
e questo:
> dt[,lapply(.SD,`==`,6)]
a b
1: FALSE FALSE
2: FALSE FALSE
3: FALSE TRUE
e, inoltre, che:
> dt[,lapply(.SD,function(x) any(x==6))]
a b
1: FALSE TRUE
Ma non riesco originale colonna:
b
1: 4
2: 5
3: 6