很多时候我想转换一个列表,其中每个索引具有与数据框相同的元素类型。例如,我可能有一个列表:什么是最有效的方式将列表投入数据框?
> my.list
[[1]]
[[1]]$global_stdev_ppb
[1] 24267673
[[1]]$range
[1] 0.03114799
[[1]]$tok
[1] "hello"
[[1]]$global_freq_ppb
[1] 211592.6
[[2]]
[[2]]$global_stdev_ppb
[1] 11561448
[[2]]$range
[1] 0.08870838
[[2]]$tok
[1] "world"
[[2]]$global_freq_ppb
[1] 1002043
我想将此列表转换为数据框,其中每个索引元素是一列。自然(我)的事情去是为使用do.call
:足够
> my.matrix<-do.call("rbind", my.list)
> my.matrix
global_stdev_ppb range tok global_freq_ppb
[1,] 24267673 0.03114799 "hello" 211592.6
[2,] 11561448 0.08870838 "world" 1002043
简单,但是当我试图施放此矩阵作为一个数据帧,列保持列表元素,而不是载体:
> my.df<-as.data.frame(my.matrix, stringsAsFactors=FALSE)
> my.df[,1]
[[1]]
[1] 24267673
[[2]]
[1] 11561448
目前,得到数据帧投妥善我使用unlist
和as.vector
遍历每个列,然后重铸数据帧,例如:
new.list<-lapply(1:ncol(my.matrix), function(x) as.vector(unlist(my.matrix[,x])))
my.df<-as.data.frame(do.call(cbind, new.list), stringsAsFactors=FALSE)
但是,这看起来效率很低。有没有更好的方法来做到这一点?
看`?data.table :: rbindlist` – marbel 2016-12-22 17:13:20
2017年,你应该使用`your_list%>%减少(bind_rows)``从purrr` – Zafar 2017-03-06 21:32:29