[英]R remove list full of NA from a list of lists
我有一个列表列表,可能包含NA值。 如何删除充满NA值的列表,请记住,如果列表中存在非NA值,则不应删除这些值和NA值?
输入示例:
myList <- list()
myList[[1]] <- c(1,2,3)
myList[[2]] <- c(4,5)
myList[[3]] <- c(NA,NA,NA,NA,NA)
myList[[4]] <- c(NA, 6, 7, NA)
myList[[5]] <- NA
所需的输出是:
[[1]]
[1] 1 2 3
[[2]]
[1] 4 5
[[3]]
[1] NA 6 7 NA
到目前为止,我能够做到:
test <- lapply(myList, function(x) x[!all(is.na(x))])
得到输出:
[[1]]
[1] 1 2 3
[[2]]
[1] 4 5
[[3]]
logical(0)
[[4]]
[1] NA 6 7 NA
[[5]]
logical(0)
另一个选择是discard
library(purrr)
discard(myList, ~ all(is.na(.x)))
#[1]]
#[1] 1 2 3
#[[2]]
#[1] 4 5
#[[3]]
#[1] NA 6 7 NA
Filter
救援:
Filter(function(x) !all(is.na(x)), myList)
#[[1]]
#[1] 1 2 3
#
#[[2]]
#[1] 4 5
#
#[[3]]
#[1] NA 6 7 NA
您可以使用至少一个非NA值对列表元素进行子集化:
> myList[sapply(myList, function(x) sum(!is.na(x))) > 0]
[[1]]
[1] 1 2 3
[[2]]
[1] 4 5
[[3]]
[1] NA 6 7 NA
您可以通过为其分配NULL
来“杀死”元素。
myList[sapply(myList,function(x) all(is.na(x)))] <- NULL
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.