我有一个列表,其中每个列表元素本身都包含另一个包含多个名称对象的列表。这些命名对象中的每一个都是相同长度的向量。我的目标是通过连接向量有效地将相关对象(同名对象)组合成一个矩阵。
这是我正在使用的结构类型的示例。但是,在当前应用程序中,它来自 mclapply,因为它是一个并行化的多级模型,我认为没有办法返回列表列表。
> test=lapply(1:2,function(x){out = list(); out$t=rnorm(3)+x; out$p =rnorm(3)+ x+.1; return(out)})
> test
[[1]]
[[1]]$t
[1] 0.5950165 0.8827352 0.5614947
[[1]]$p
[1] 2.6144102 1.9688743 0.6241944
[[2]]
[[2]]$t
[1] 2.562030 1.832571 3.018756
[[2]]$p
[1] 1.7431969 0.5305784 2.6935106
这是完成我想要的粗略方法
> t.matrix = cbind(test[[1]]$t,test[[2]]$t)
> t.matrix
[,1] [,2]
[1,] 2.2094525 2.634907
[2,] -0.2822453 2.440666
[3,] 1.1704518 2.483424
但相反,我希望能够为很长的列表(大约 100 万个元素)执行此操作,而我当前的解决方案无法扩展。
我想我可以使用 for 循环,但似乎必须有更好的方法来巧妙地使用 reduce 或 unlist 或 sapply 或类似的东西。