Ejemplo mínimo:
dt <- data.table(a=c(1,2,3),b=c(4,5,6))
Que se parece a:
> dt
a b
1: 1 4
2: 2 5
3: 3 6
Supongamos que quiero índice de la columna donde hay una 6
valor, en este juguete ejemplo, es fácil, ya que sabemos de la columna:
> dt[,.(b)]
b
1: 4
2: 5
3: 6
Ahora lo que si esta dt
tenía varios miles de columnas y no sabríamos donde el 6
mentiras.
He intentado esto:
> dt[,.SD==6]
a b
[1,] FALSE FALSE
[2,] FALSE FALSE
[3,] FALSE TRUE
y esto:
> dt[,lapply(.SD,`==`,6)]
a b
1: FALSE FALSE
2: FALSE FALSE
3: FALSE TRUE
y también que:
> dt[,lapply(.SD,function(x) any(x==6))]
a b
1: FALSE TRUE
Pero no puedo conseguir el original de la columna de la espalda:
b
1: 4
2: 5
3: 6