47

我在列表中创建了一些列表,并希望能够让每个子列表元素成为顶层的单个元素。

例如创建一些虚拟数据:

pp <- lapply(10:15,function(y){
    lapply(10:20,function(z){
        as.data.frame(matrix(rnorm(z*y),nrow=z,ncol=y))
    })  
})

这将创建以下输出

> summary(pp)
     Length Class  Mode
[1,] 11     -none- list
[2,] 11     -none- list
[3,] 11     -none- list
[4,] 11     -none- list
[5,] 11     -none- list
[6,] 11     -none- list

你也可以在哪里做

> summary(pp[[1]])
      Length Class      Mode
 [1,] 10     data.frame list
 [2,] 10     data.frame list
 [3,] 10     data.frame list
 [4,] 10     data.frame list
 [5,] 10     data.frame list
 [6,] 10     data.frame list
 [7,] 10     data.frame list
 [8,] 10     data.frame list
 [9,] 10     data.frame list
[10,] 10     data.frame list
[11,] 10     data.frame list

结果输出只会创建一个新列表,其内容如下:

new.pp[[1]] <- pp[[1]][[1]]
new.pp[[2]] <- pp[[1]][[2]]

但是想知道当列表中有列表时是否有一种智能或更有效的方法来删除一级列表....

理想情况下,我正在寻找某种为我执行此操作的函数,因此,例如,如果我有多个级别的列表相互嵌套而不是只有两个,我可以递归地在每个级别使用该函数最终将每个元素带到列表的顶部......

4

2 回答 2

67

我认为这可以解决问题

new.pp <- unlist(pp,recursive=FALSE)
于 2013-06-18T09:06:21.067 回答
6

Tidyverse 方法:

library(purrr)
new.pp <- flatten(pp)
于 2020-04-24T06:05:32.110 回答