我想将字符串列表转换为数据框。
给定结构:
lst <- list(NULL, "PSYC", c("PSYC", "PHIL"), "PHIL")
我想生成一个数据框
Index major_cd
1 NULL
2 PSYC
3 PSYC
3 PHIL
4 PHIL
请注意列表中的第三项如何变成数据框的 2 行。
最佳答案
我们可以用 'NA' 或 "NULL"替换 'lst' 中的 NULL 元素,并在设置 'lst' 的名称后使用 unnest
中的 tidyr
lst[sapply(lst, is.null)] <- NA
或者正如@David Arenburg 在评论中提到的那样,设置为
"NULL"
而不是 NA
将给出如图所示的预期输出library(tidyr)
unnest(setNames(lst, seq_along(lst)), Index)
# Index x
#1 1 <NA>
#2 2 PSYC
#3 3 PSYC
#4 3 PHIL
#5 4 PHIL
关于r - 如何将字符串列表转换为数据框?,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/30200428/