将未命名的规则结构化的R列表转换为已命名的R列表

时间:2018-10-22 23:11:18

标签: r

我有一个奇怪的R列表,其中作为字符串的奇数列表元素应该是偶数列表元素的名称。一些元素是列表中的列表。列表的深度不是预先定义的。列表的简化结构大致为:

a <- list("key0",
          "value0",
          "key",
          list("key1", "value1",
               "key2", "value2", 
               "key3",  list("key6", "value6"),
               "key4", "value4",
               "key5", list(list(list("key7", "value7")))
          ))

如何从列表a中获得名为R的常规列表b

b <- list(key0 = "value0",
          key = list(key1 = "value1",
                     key2 = "value2", 
                     key3 = list(key6  = "value6"),
                     key4 = "value4",
                     key5 = list(list(list(key7 = "value7")))
          ))

列表a之类的数据结构是否有特殊的技术名称?

1 个答案:

答案 0 :(得分:4)

使用递归函数:

fun <- function(x){
  x <- lapply(x,function(y) if (is.list(y)) y <- fun(y) else y)
  if(!is.null(names(x)) | length(x) == 1) return(x)
  x <- setNames(x[seq_along(x)%%2 == 0], x[seq_along(x)%%2 == 1])
  x
}
res <- fun(a)

identical(b,res)
# [1] TRUE