0

我有一个大小均匀的字符向量列表,我希望将它们有效地组合到一个数据帧中,列表中的向量成为新数据帧的行。下面ls是我的列表,df是我预先分配的数据框。

ls <- list(c("r1c1", "r1c2", "r1c3"),
           c("r2c1", "r2c2", "r2c3"))

df <- data.frame(col1 = character(), col2 = character(), col3 = character(),
                 stringsAsFactors = F)

# Desired Result:
  col1   col2   col3
1  r1c1   r1c2   r1c3       
2  r2c1   r2c2   r2c3  

截至目前,我已经尝试过rbind(df, ls)似乎按列创建新数据框,df如下所示:

  c..r1c1....r1c2....r1c3.. c..r2c1....r2c2....r2c3..
4                      r1c1                      r2c1
5                      r1c2                      r2c2
6                      r1c3                      r2c3

我也尝试过执行rbindfor 循环的内部:

for (i in 1:length(ls))
  df <- rbind(df, ls[[i]])

然而,这给了我警告信息:invalid factor level, NA generated,即使我最初设置stringsAsFactors为 false。当在较大的列表上不断执行时,Rbind 似乎也是一个缓慢的过程,所以如果可能的话,我想尽量减少它的使用。

任何帮助将不胜感激。

4

1 回答 1

8

你可以使用

 data.frame(do.call(rbind, ls))

作为将向量列表转换为矩阵然后是 data.frame 的一种快速简单的方法

于 2014-07-28T04:35:50.660 回答