我有一个dd2包含数百列的数据框,我需要做的是将所有这些列值粘贴在一起,省略任何NA值.如果我做这样的事情
apply(dd2, 1, paste, collapse=",")
Run Code Online (Sandbox Code Playgroud)
它实际上包括NAs作为"NA"字符串.我想避免这种情况.我也可以如下所示,但是这会让我一次为每个单独的列工作以获得结果.
result <- cbind(
dd2,
combination = paste(dd2[,2], replace(dd2[,3], is.na(dd2[,3]), ""), sep = ",")
)
Run Code Online (Sandbox Code Playgroud)
有没有有效的方法呢?以下是示例数据:
dd2 <- structure(c("A", "B", "C", "D", "E", "AK2", "HFM1", NA, "TRR",
"RTT", NA, "PPT", "TRR", "RTT", NA, "PPT", NA, NA, "GGT", NA), .Dim = c(5L,
4L), .Dimnames = list(NULL, c("sample_id", "plant", "animal",
"more")))
Run Code Online (Sandbox Code Playgroud)
您可以尝试na.omit()省略值,然后粘贴.此外,您可以使用toString(),因为它相当于paste(..., collapse = ", ").
apply(dd2, 1, function(x) toString(na.omit(x)))
# [1] "A, AK2, PPT" "B, HFM1, PPT" "C, TRR"
# [4] "D, TRR, RTT, GGT" "E, RTT"
Run Code Online (Sandbox Code Playgroud)
如果您有特定的列,那么您正在使用
apply(dd2[, cols], 1, function(x) toString(na.omit(x)))
Run Code Online (Sandbox Code Playgroud)