66

我在将数据附加到已经采用列表格式的列表时遇到问题。我有一个程序将在模拟循环期间导出结果对象。数据本身存储为矩阵列表。我的想法是将这些列表存储在一个列表中,然后将此列表列表保存为 R 对象以供以后分析,但是我在正确实现这一点时遇到了一些问题。我将展示我对小型抽象示例所做的事情,仅使用值而不是模拟中的矩阵数据:

假设我已经运行了 3 次模拟循环。在迭代期间,需要将结果列表收集到我将保存为 R 对象的一个​​列表列表中:

List 包含其他列表并被保存: outlist1 <- list()

第一次迭代: resultsa <- list(1,2,3,4,5)

outlist <- append(outlist1,resultsa)

第二次迭代: resultsb <- list(6,7,8,9,10)

outlist <- append(outlist1,b)

第三次迭代: resultsc <- list(11,12,13,14,15)

outlist <- list(outlist2,c)

但是,此解决方案不适用于以这种方式增长包含列表的列表,所需的结果是:

>outlist
[[1]]
[[1]][[1]]
[1] 1

[[1]][[2]]
[1] 2

[[1]][[3]]
[1] 3

[[1]][[4]]
[1] 4

[[1]][[5]]
[1] 5


[[2]]
[[2]][[1]]
[1] 6

[[2]][[2]]
[1] 7

[[2]][[3]]
[1] 8

[[2]][[4]]
[1] 9

[[2]][[5]]
[1] 10


[[3]]
[[3]][[1]]
[1] 11

[[3]][[2]]
[1] 12

[[3]][[3]]
[1] 13

[[3]][[4]]
[1] 14

[[3]][[5]]
[1] 15

然而,我得到的是:

> outlist3
[[1]]
[[1]][[1]]
[[1]][[1]][[1]]
[1] 1

[[1]][[1]][[2]]
[1] 2

[[1]][[1]][[3]]
[1] 3

[[1]][[1]][[4]]
[1] 4

[[1]][[1]][[5]]
[1] 5


[[1]][[2]]
[[1]][[2]][[1]]
[1] 6

[[1]][[2]][[2]]
[1] 7

[[1]][[2]][[3]]
[1] 8

[[1]][[2]][[4]]
[1] 9

[[1]][[2]][[5]]
[1] 10

如何增加列表,以使格式化的结果列表类似于所需的结果?如果我对这些列表进行进一步分析,我需要能够轻松访问这些元素。

4

7 回答 7

84

会不会是这个,你想要的:

# Initial list:
myList <- list()

# Now the new experiments
for(i in 1:3){
  myList[[length(myList)+1]] <- list(sample(1:3))
}

myList
于 2013-02-13T07:12:57.167 回答
24
outlist <- list(resultsa)
outlist[2] <- list(resultsb)
outlist[3] <- list(resultsc)

append的帮助文件说它是用于向量的。但它可以在这里使用。我以为我以前尝试过,但是 OP 的代码中有一些奇怪的异常可能会误导我:

outlist <- list(resultsa)
outlist <- append(outlist,list(resultsb))
outlist <- append(outlist,list(resultsc))

结果相同。

于 2013-02-13T07:56:11.673 回答
15

还有其他两种解决方案涉及分配给列表末尾之后的索引。这是一个使用append.

resultsa <- list(1,2,3,4,5)
resultsb <- list(6,7,8,9,10)
resultsc <- list(11,12,13,14,15)

outlist <- list(resultsa)
outlist <- append(outlist, list(resultsb))
outlist <- append(outlist, list(resultsc))

这给出了您要求的格式

> str(outlist)
List of 3
 $ :List of 5
  ..$ : num 1
  ..$ : num 2
  ..$ : num 3
  ..$ : num 4
  ..$ : num 5
 $ :List of 5
  ..$ : num 6
  ..$ : num 7
  ..$ : num 8
  ..$ : num 9
  ..$ : num 10
 $ :List of 5
  ..$ : num 11
  ..$ : num 12
  ..$ : num 13
  ..$ : num 14
  ..$ : num 15
于 2013-02-13T16:08:57.307 回答
10

这个答案类似于公认的答案,但不那么复杂。

L<-list()
for (i in 1:3) {
L<-c(L, list(list(sample(1:3))))
}
于 2015-05-21T02:46:33.540 回答
6

通过首先将列表赋值给变量

myVar <- list()

它开启了等级分配的可能性

myVar[[1]] <- list()
myVar[[2]] <- list()

等等......所以现在可以做

myVar[[1]][[1]] <- c(...)
myVar[[1]][[2]] <- c(...)

或者

myVar[[1]][['subVar']] <- c(...)

等等

也可以直接指定名称(而不是 $)

myVar[['nameofsubvar]] <- list()

进而

myVar[['nameofsubvar]][['nameofsubsubvar']] <- c('...')

要记住的重要一点是始终使用双括号来使系统正常工作

那么获取信息很简单

myVar$nameofsubvar$nameofsubsubvar

等等...

例子:

a <-list()
a[['test']] <-list()
a[['test']][['subtest']] <- c(1,2,3)
a
$test
$test$subtest
[1] 1 2 3


a[['test']][['sub2test']] <- c(3,4,5)
a
$test
$test$subtest
[1] 1 2 3

$test$sub2test
[1] 3 4 5

R语言的一个很好的特性是它的层次定义......

我将它用于复杂的实现(具有两个以上的级别)并且它有效!

于 2013-10-28T23:35:39.377 回答
1

只需在下面对 Brian 的回答进行注释,第一个分配 tooutlist也可以是一个append语句,因此您也可以执行以下操作:

resultsa <- list(1,2,3,4,5)
resultsb <- list(6,7,8,9,10)
resultsc <- list(11,12,13,14,15)

outlist <- list()
outlist <- append(outlist,list(resultsa))
outlist <- append(outlist, list(resultsb))
outlist <- append(outlist, list(resultsc))

如果您想在循环中从头开始构建列表,这有时会很有帮助。

于 2019-11-24T07:05:51.437 回答
1

purrr软件包具有许多用于处理列表的便捷功能。该flatten命令可以清除不需要的嵌套。

resultsa <- list(1,2,3,4,5)
resultsb <- list(6,7,8,9,10)
resultsc <- list(11,12,13,14,15)

nested_outlist <- list(resultsa, resultsb, resultsc)
outlist <- purrr::flatten(nested_outlist)
于 2020-08-04T07:28:37.657 回答