忽略 dplyr 行总和中的 NA [英] ignore NA in dplyr row sum
本文介绍了忽略 dplyr 行总和中的 NA的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
是否有一种优雅的方法可以在 dplyr 中将 NA 处理为 0 (na.rm = TRUE)?
is there an elegant way to handle NA as 0 (na.rm = TRUE) in dplyr?
data <- data.frame(a=c(1,2,3,4), b=c(4,NA,5,6), c=c(7,8,9,NA))
data %>% mutate(sum = a + b + c)
a b c sum
1 4 7 12
2 NA 8 NA
3 5 9 17
4 6 NA NA
但我喜欢得到
a b c sum
1 4 7 12
2 NA 8 10
3 5 9 17
4 6 NA 10
即使我知道在许多其他情况下这不是理想的结果
even if I know that this is not the desired result in many other cases
推荐答案
你可以使用这个:
library(dplyr)
data %>%
#rowwise will make sure the sum operation will occur on each row
rowwise() %>%
#then a simple sum(..., na.rm=TRUE) is enough to result in what you need
mutate(sum = sum(a,b,c, na.rm=TRUE))
输出:
Source: local data frame [4 x 4]
Groups: <by row>
a b c sum
(dbl) (dbl) (dbl) (dbl)
1 1 4 7 12
2 2 NA 8 10
3 3 5 9 17
4 4 6 NA 10
这篇关于忽略 dplyr 行总和中的 NA的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!
查看全文