一个是包含列表清单:提取塔它是由清单
a<-list(list(matrix(c(0,0,0,1,2,1,2,2,2,1,1,1),3),
matrix(c(0,0,1,2,2,2,2,1),2)),
list(matrix(c(0,0,1,2,2,1,1,1,2,2,2,2),3)))
> a
[[1]]
[[1]][[1]]
[,1] [,2] [,3] [,4]
[1,] 0 1 2 1
[2,] 0 2 2 1
[3,] 0 1 2 1
[[1]][[2]]
[,1] [,2] [,3] [,4]
[1,] 0 1 2 2
[2,] 0 2 2 1
[[2]]
[[2]][[1]]
[,1] [,2] [,3] [,4]
[1,] 0 2 1 2
[2,] 0 2 1 2
[3,] 1 1 2 2
我想提取所有对象的拳头列。我们知道如果列表是由矩阵组成的,我们可以使用“Map”函数来解决这个问题,但是现在列表是由列表组成的,我们不能用“Map”来解决这个问题,我该怎么办这很容易?
我用下面的代码来解决这个问题:
sapply(1:length(a), function(x) {Map(function(y) y[,1],a[[x]])})
它是可以解决的,但我不知道是否有解决这个问题的一个更方便的方法,因为我需要做的后来基于更多的作品这个问题。谢谢!
@rawr你让我碰到“rapply”,谢谢! – lightsnail
@rawr - 这真的应该是这里的答案 - 它是通用和可扩展的 – thelatemail