我有一个数据框列表,其中一些数据框的列数较少。见例:
a <- data.frame (x1 = 1, x3 = 2, x4 = 7)
b <- data.frame (x1 = 3, x2 = 4, x3 = 3, x4 = 8)
c <- data.frame (x1 = 9, x2 = 5, x3 = 2, x4 = 9)
myList = list(a, b, c)
数据框a
错过了列x2
。我需要从myList中获取一个数据框,所以我执行以下操作:
mydf = do.call(rbind, myList)
但问题是我收到以下错误:
Error in rbind(deparse.level, ...) :
numbers of columns of arguments do not match
如何获取x2
的{{1}}列a
填充NA
的数据框?
答案 0 :(得分:4)
您可以使用data.table
:
library(data.table)
rbindlist(myList, fill = TRUE)
# x1 x3 x4 x2
#1: 1 2 7 NA
#2: 3 3 8 4
#3: 9 2 9 5