在嵌套列表的不同级别上应用函数(重新发布)

4

旧文章:

我在想是否有可能在嵌套列表的不同层次中应用函数,rapply可以在列表中递归地应用函数,但是在同一层级中。我的问题涉及在不同长度的不同层次上应用函数。以下是一个示例以说明:

list <- list(list(a=1:5, b=5:9, c=6:10, d=1:5),
             list(e=2:6, f=3:7, g=8:12),
             list(h=3:7, i=6:10, j=11:15, k=2:6),
             list(l=4:8, m=2:6),
             list(n=5:9, o=1:5, p=2:6, q=0:4),
             list(r=6:10, s=3:7, t=9:13))

我想把一个函数(例如 sum)应用于第一个元素(例如[[1]]$a=1, [[1]]$b=5, [[1]]$c=6, [[1]]d=1),然后应用于第二个元素(例如 [[1]]$a=2, [[1]]$b=6, [[1]]$c=7, [[1]]$d=2),以此类推。结果应该像这样:
[[1]]
13 17 21 25 29

[[2]]
13 16 19 22 25

[[3]]
22 26 30 34 38

[[4]]
6 8 10 12 14

[[5]]
8 12 16 20 24

[[6]]
18 21 24 27 30

也许可以结合使用rapplymapply

谢谢

新帖子:

@G.Grothendieck已经给了我一个很好的解决方案,但是我有另一个列表,其中包含p值,我想应用更复杂的函数,例如mean或其他函数。

Fisher.test <- function(p) {
  Xsq <- -2*sum(log(p))
  p.val <- 1-pchisq(Xsq, df = 2*length(p))
  return(p.val)
}

Reduce函数无法像sumf="+"那样起作用,有什么建议吗?

这是一个示例,展示了这个新列表的样子。

pval.list <- list(list(a=c(0.05, 0.0001, 0.32, 0.45), b=c(0.1,0.12,0.01,0.06), c=c(0.1,0.12,0.01,0.06), d=c(0.01,0.02,0.03,0.04)),
             list(e=c(0.04, 0.1, 0.232, 0.245), f=c(0.05, 0.01, 0.22, 0.54), g=c(0.005, 0.1, 0.032, 0.045)),
             list(h=c(0.03, 0.01, 0.12, 0.4), i=c(0.5, 0.0001, 0.132, 0.045), j=c(0.005, 0.0001, 0.0032, 0.045), k=c(0.5, 0.1, 0.932, 0.545)),
             list(l=c(0.022, 0.0012, 0.32, 0.45), m=c(0.0589, 0.0001, 0.0032, 0.0045)),
             list(n=c(0.051, 0.01, 0.32, 0.45), o=c(0.05, 0.0001, 0.32, 0.45), p=c(0.05, 0.0001, 0.32, 0.45), q=c(0.05, 0.0001, 0.32, 0.45)),
             list(r=c(0.053, 0.001, 0.32, 0.45), s=c(0.05, 0.0001, 0.32, 0.45), t=c(0.05, 0.0001, 0.32, 0.45)))
1个回答

4

试试这个:

> lapply(list, Reduce, f = "+")
[[1]]
[1] 13 17 21 25 29

[[2]]
[1] 13 16 19 22 25

[[3]]
[1] 22 26 30 34 38

[[4]]
[1]  6  8 10 12 14

[[5]]
[1]  8 12 16 20 24

[[6]]
[1] 18 21 24 27 30

不错的技巧 @G.Grothendieck,你能解释一下 Reduce 函数是做什么的吗?还可以使用其他函数,比如 mean 吗?谢谢。 - user2380782
Reduce(f = "+", x) 相当于 x[[[1]] + ... + x[[n]] - G. Grothendieck

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接