首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >NA +0= 0,NA +1= 1,NA + NA =R中的NA

NA +0= 0,NA +1= 1,NA + NA =R中的NA
EN

Stack Overflow用户
提问于 2021-09-03 08:11:17
回答 1查看 44关注 0票数 0

我有一个包含一些NAs的数据帧,如下所示:

代码语言:javascript
复制
set.seed(1)
M<-matrix(sample(0:1,100,replace=TRUE),ncol=10)
M <- as.data.frame(M)
M[3,1]<-NA
M[10,5]<-NA
M[10,6]<-NA
M[8,10]<-NA

我想每两列求和如下: M_final = Mc(TRUE,FALSE)+Mc(FALSE,TRUE)

但我希望只有在添加了两个NA时,才在M_final中包含NA。因此,我希望输出结果是:

代码语言:javascript
复制
   V1 V3 V5 V7 V9
1   0  1  2  1  1
2   1  1  1  2  1
3   0  0  1  1  1
4   0  1  2  1  1
5   1  0  1  1  0
6   1  0  1  2  1
7   1  2  2  2  0
8   1  0  2  0  1
9   2  1  1  1  1
10  1  2 NA  2  1

有什么想法吗?谢谢!!

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2021-09-03 08:22:00

您可以编写一个自定义函数来处理此问题。

代码语言:javascript
复制
add_NA <- function(x, y) ifelse(is.na(x) & is.na(y), NA, rowSums(cbind(x, y), na.rm = TRUE))

使用mapply将它们成对应用

代码语言:javascript
复制
mapply(add_NA, M[c(TRUE,FALSE)], M[c(FALSE,TRUE)])

#.     V1 V3 V5 V7 V9
# [1,]  0  1  2  1  1
# [2,]  1  1  1  2  1
# [3,]  0  0  1  1  1
# [4,]  0  1  2  1  1
# [5,]  1  0  1  1  0
# [6,]  1  0  1  2  1
# [7,]  1  2  2  2  0
# [8,]  1  0  2  0  1
# [9,]  2  1  1  1  1
#[10,]  1  2 NA  2  1
票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/69041570

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档