我有一个包含许多列的data.frame。我想保留其中4列中没有NA的行。复杂性源于这样一个事实:我有其他行允许在其中有NA,所以我不能使用complete.cases或is.na.最有效的方法是什么?
答案 0 :(得分:17)
您仍然可以使用complete.cases()
。只需将它应用于所需的列(下例中的第1列:第4列),然后使用它返回的布尔向量从整个data.frame中选择有效的行。
set.seed(4)
x <- as.data.frame(replicate(6, sample(c(1:10,NA))))
x[complete.cases(x[1:4]),]
# V1 V2 V3 V4 V5 V6
# 1 7 4 6 8 10 5
# 2 1 2 5 5 1 2
# 5 6 8 4 10 6 6
# 6 2 6 9 3 4 4
# 7 4 3 3 1 2 1
# 9 8 5 2 7 7 3
# 10 10 10 1 2 5 NA