繁体   English   中英

通过lapply过滤R中的对象列表

[英]Filtering List of Objects in R through lapply

如何构造一个lapply函数来通过索引提取特定对象? 我有一份清单。 我现在想要获得列表中每个偶数的第2,第4和第5个元素并将它们放入数据框中。 我认为最简单的方法是使用lapply并简单地获取如下条目:

list <-lapply(ll, function(x) { x[[2]]; x[[4]]; x[[5]] }

但这似乎不会起作用。

这将工作:

ll <- list(as.list(1:10),
           as.list(11:20),
           as.list(21:30))

library(magrittr)

output1 <- ll %>% sapply(function(x){c(x[[2]],x[[4]],x[[5]])}) %>% t %>% as.data.frame
# or with base syntax:
output2 <- as.data.frame(t(sapply(ll,function(x){c(x[[2]],x[[4]],x[[5]])})))
    #   V1 V2 V3
    # 1  2  4  5
    # 2 12 14 15
    # 3 22 24 25

你的函数返回最后一个操作的结果,在你的情况下是``x [[5]]`。 你之前做的2个操作都会丢失。

不确定您希望这个data.frame看起来像什么,但您可以使用提取2个,4个和5个元素

lapply(ll, `[`, c(2,4,5))

如果你想将它们变成行,你可以这样做

do.call("rbind",lapply(ll, `[`, c(2,4,5)))

如果你想让它们成为专栏,你可以做到

data.frame(sapply(ll, `[`, c(2,4,5)))

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM