【发布时间】:2020-02-18 19:30:24
【问题描述】:
我需要将以下列表转换为数据框:
list(c(13, 5, 9, 16, 1, 7, 3, 20), c(0, 1, 2, 7, 8, 14, 20), c(2, 4, 7, 9, 12, 14, 16), 0:9, c(18, 19, 20, 21, 22, 23, 6, 7, 8, 9), c(0, 1, 7, 13, 19, 6, 12, 18, 2, 8), 23:22, c(18, 13, 8), c(18, 13, 8, 3, 10, 17, 12, 6, 0, 1), c(18, 14), c(18, 19, 20, 21, 13, 7, 8, 14, 2, 1), c(13, 15, 16, 9, 8, 7, 14, 20, 19, 18))
列表结构如下:
List of 1
$ :List of 12
..$ : int [1:8] 13 5 9 16 1 7 3 20
..$ : int [1:7] 0 1 2 7 8 14 20
..$ : int [1:7] 2 4 7 9 12 14 16
..$ : int [1:10] 0 1 2 3 4 5 6 7 8 9
..$ : int [1:10] 18 19 20 21 22 23 6 7 8 9
..$ : int [1:10] 0 1 7 13 19 6 12 18 2 8
..$ : int [1:2] 23 22
..$ : int [1:3] 18 13 8
..$ : int [1:10] 18 13 8 3 10 17 12 6 0 1
..$ : int [1:2] 18 14
..$ : int [1:10] 18 19 20 21 13 7 8 14 2 1
..$ : int [1:10] 13 15 16 9 8 7 14 20 19 18
因为每个向量都可以包含 12 个整数,所以我想将此列表转换为如下所示的数据框:
P01 P02 P03 P04 P05 P06 P07 P08 P09 P10 P11 P12
D01 13 5 9 16 1 7 3 20 NA NA NA NA
D02 0 1 2 7 8 14 20 NA NA NA NA NA
D03 2 4 7 9 12 14 16 NA NA NA NA NA
... and so on
非常感谢任何修复提示。
【问题讨论】:
-
data.table::rbindlist(lapply(d, function(x) setNames(data.frame(t(x)), paste0("P", seq_along(x)))), fill = TRUE)