Se podría dar vuelta a su primera lista en un hoja.de.datos que asigna valores a su índice correspondiente en la lista:
ll <- list(c("7", "12", "26", "29"),
c("11", "36"),
c("20", "49"),
c("39", "41"))
df <- data.frame(value = unlist(ll),
index = rep(seq_along(ll), lapply(ll, length)))
df
# value index
# 1 7 1
# 2 12 1
# 3 26 1
# 4 29 1
# 5 11 2
# 6 36 2
# 7 20 3
# 8 49 3
# 9 39 4
# 10 41 4
Luego, escribe una función utilizando match
para encontrar el índice del primer producirse rencia de un valor dado:
find.idx <- function(val)df$index[match(val, df$value)]
Usted puede llamar a esta función en un solo valor, o muchas a la vez desde match
se vectorizado:
find.idx("36")
# [1] 2
find.idx(c("36", "41", "99"))
# [1] 2 4 NA
Por supuesto, también se puede ejecutar a través de lapply
, sobre todo si va a ejecutar en paralelo:
lapply(c("36", "41", "99"), find.idx)
# [[1]]
# [1] 2
#
# [[2]]
# [1] 4
#
# [[3]]
# [1] NA
para la ejecución de este último bit en paralelo, hay muchas, muchas opciones. Le recomendaría que sopese sus opciones buscando en http://cran.r-project.org/web/views/HighPerformanceComputing.html.
Tal vez algo como 'lapply (component_list, function (x) any (match (x," 36 ")))' te acerca. –
Su ejemplo es ambiguo porque "36" es el segundo elemento de la lista y el segundo elemento en el segundo elemento de la lista. –