我想将字符串列表转换为数据框。
给定结构:

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/

10-17 01:26