微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

寻找在有 NA 时利用 ifelse 的 R 函数

如何解决寻找在有 NA 时利用 ifelse 的 R 函数

我有这些数据,我需要其中的输出,如图所示。

  • 如果 a 为 0 且 b 为 0 ,则 c 被赋值为 0
  • 如果 a 是 0 而 b 是 1 ,那么 c 被赋值为 1
  • 如果 a 是 0 而 b 是 NA ,那么 c 被赋值为 0
  • 如果 a 是 1 而 b 是 NA ,那么 c 被赋值为 1
    a<-c(0,1,1)
    b<-c(1,NA,NA)
    data<-data.frame(a,b)
    
    data$c<-c(1,1)

解决方法

这两种方法都适用于即时情况

pmax(a,b,na.rm = T)
[1] 1 0 0 1 1 1 0 1

data$c <- +(as.logical(rowSums(data,na.rm = T)))

 data$c
[1] 1 0 0 1 1 1 0 1

dplyr::if_else 有一个最后一个参数来提供一个附加值,如果提供的条件导致 NA

,

也许是这样:

apply(data,1,max,na.rm=T)
1 0 0 1 1 1 0 1

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。