12

我有一个包含许多列的 data.frame。我想在其中 4 列中保留没有 NA 的行。复杂性源于我有其他允许在其中包含 NA 的行,因此我不能使用 complete.cases 或 is.na。最有效的方法是什么?

4

1 回答 1

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
于 2012-10-22T15:52:17.940 回答