如何将具有不同数据类型的嵌套列表转换为数据框?
我有一个包含不同类型嵌套元素的列表
library(tidyverse)
# list to be transfomed into a dataframe/tibble
mylist <-
list(
lois = list(
hair = list(color = "orange", form = "flat"),
sex = "female"
)
)
# structure
str(mylist)
#> List of 1
#> $ lois:List of 2
#> ..$ hair:List of 2
#> .. ..$ color: chr "orange"
#> .. ..$ form : chr "flat"
#> ..$ sex : chr "female"
目标是将此列表转换为数据框/tibble。所需的输出是
# A tibble: 3 x 4
name value_id attribute text
<chr> <chr> <chr> <chr>
1 lois hair color orange
2 lois hair form flat
3 lois sex NA female
我试过了tidyr::unnest_longer()。但是很难取消嵌套,因为 column 中有不同的类型value:
# unnest_longer does not work like this
mylist %>%
enframe() %>%
unnest_longer(col = value) %>%
unnest_longer(col = value)
#> Error: Can't combine `..1$value` <list> and `..2$value` <character>.
由reprex 包(v0.3.0)于 2021 年 1 月 13 日创建
这个问题有什么好的解决方案?
回答
一种选择是使用rrapply库:
rrapply(mylist, how = "melt")
L1 L2 L3 value
1 lois hair color orange
2 lois hair form flat
3 lois sex <NA> female