首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用dplyr::mutate/mutate_if具有多个条件的Ifelse语句

使用dplyr::mutate/mutate_if具有多个条件的Ifelse语句
EN

Stack Overflow用户
提问于 2018-06-02 05:55:51
回答 1查看 1.2K关注 0票数 2

如果一组变量中的任何变量是10,则使用dplyr::mutate和基本any函数,我想创建一个新变量,使其成为dplyr::mutate

数据集:

代码语言:javascript
复制
df <- structure(list(ID = 1:2, METFORMIN = c(0L, 0L), SULPHONYLUREA = c(0L, 0L), MEGLITINIDE = c(0L, 0L), ACARBOSE = c(0L, 0L),
                     THIAZOLIDINEDIONE = c(0L, 0L), DPP4_INHIBITOR = c(0L, 0L), SGLT2_INHIBITOR = c(1L, 1L), GLP1_RA = c(0L, 0L)), 
                .Names = c("ID", "METFORMIN", "SULPHONYLUREA", "MEGLITINIDE", "ACARBOSE", "THIAZOLIDINEDIONE", "DPP4_INHIBITOR",
                           "SGLT2_INHIBITOR", "GLP1_RA"), class = "data.frame", row.names = c(NA, -2L))

数据结构:

代码语言:javascript
复制
 #  ID METFORMIN SULPHONYLUREA MEGLITINIDE ACARBOSE THIAZOLIDINEDIONE DPP4_INHIBITOR SGLT2_INHIBITOR GLP1_RA
 #  1          0             0           0        0                 0              0               1       0
 #  2          0             0           0        0                 0              0               1       0

所需的数据结构:

代码语言:javascript
复制
 #  ID METFORMIN SULPHONYLUREA MEGLITINIDE ACARBOSE THIAZOLIDINEDIONE DPP4_INHIBITOR SGLT2_INHIBITOR GLP1_RA ORALDM
 #  1          0             0           0        0                 0              0               1       0      1
 #  2          0             0           0        0                 0              0               1       0      1

代码1:

代码语言:javascript
复制
df %>% mutate(ORALDM = if_else(any(METFORMIN:GLP1_RA) == 1, 1, 0))

这不会提供所需的输出,并会产生错误:

警告消息: 1:在METFORMIN:GLP1_RA中:数值表达式有2个元素:只有第一个元素使用2:在METFORMIN:GLP1_RA中:数值表达式有2个元素:只有第一个元素

代码2:

代码语言:javascript
复制
df %>% mutate_if(predicate(any(METFORMIN:GLP1_RA) == 1), 1)

这也给出了一个错误:

谓词中的错误(任意(METFORMIN:GLP1_RA) == 1):找不到函数“谓词”

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2018-06-02 06:52:01

提高我对答案的评论。通过以下方式:

代码语言:javascript
复制
df %>% mutate(ORALDM = +(rowSums(.[2:9]) > 0))

或使用(当您想使用变量名称时):

代码语言:javascript
复制
df %>% mutate(ORALDM = +(rowSums(select(df, METFORMIN:GLP1_RA)) > 0))

你得到:

二甲双胍磺酰脲甲酰基无糖噻唑烷二酮DPP4_INHIBITOR SGLT2_INHIBITOR GLP1_RA ORALDM 1 0 0 0 1 2 2 0 0 0 1

data.table中实现相同的思想

代码语言:javascript
复制
library(data.table)
dt <- setDT(copy(df))

dt[, ORALDM := +(rowSums(.SD) > 0), .SDcols = METFORMIN:GLP1_RA][]

注意:不使用+,您还可以使用as.integeras.numeric

票数 4
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/50653963

复制
相关文章

相似问题

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