我有一个大小均匀的字符向量列表,我希望将它们有效地组合到一个数据帧中,列表中的向量成为新数据帧的行。下面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
我也尝试过执行rbind
for 循环的内部:
for (i in 1:length(ls))
df <- rbind(df, ls[[i]])
然而,这给了我警告信息:invalid factor level, NA generated
,即使我最初设置stringsAsFactors
为 false。当在较大的列表上不断执行时,Rbind 似乎也是一个缓慢的过程,所以如果可能的话,我想尽量减少它的使用。
任何帮助将不胜感激。