我想根据子列表元素之一的内容对子列表列表进行子集化,其方式类似于subset
处理数据帧的方式:
sublist1 <- list(data=rnorm(10), name="name1", keepMe=2)
sublist2 <- list(data=rnorm(10), name="name2", keepMe=2)
sublist3 <- list(data=rnorm(10), name="name3", keepMe=3)
myList <- list(s1=sublist1, s2=sublist2, s3=sublist3)
我想做一些类似的事情keepers <- subset[myList, keepMe==2]
,它会返回一个长度为 2 的列表。
以下几乎是我想要的:
require(plyr)
selector <- function(x) {
if (x$keepMe==2) {return(x)}
else {return(NULL)}
}
keepers <- llply(myList, selector)
除了在这种情况下不需要的列表元素不会被丢弃,它们只是被替换为NULL
.
请注意,在所有情况下,子列表都将具有相同的组件,只有组件的值会发生变化。