如何解决功能之间的R不能正确执行
我正在尝试在r中使用between函数,但是代码无法正确执行。当我运行代码时,两次调用之间的操作之一并没有满足我的要求。我认为这可能是人为错误,但我无法找出错误所在。
library(dplyr)
df<-data.frame(Motiv=c(-0.27,-0.34,-0.48,-0.546,-0.41,-0.39,-0.3,-0.44,-0.46,-0.3725,-0.16,-0.194,-0.105,-0.1,-0.0680000000000001,0.0600000000000001,0.04,0.0299999999999998,-0.27,-0.7,-0.65,-0.67,-0.55,-0.51,-0.4,-0.47,-0.38,-0.31,-0.42,-0.45,-0.53,-0.83,-0.94,-1.086,-1.07,-1.03,-1.05,-1.13,-1.33,-1.37,-1.14,-0.96,-0.87,-0.77,-0.64,-0.57,-0.12,-0.11,-0.19,-0.2,-0.22,0.0499999999999998,0.19,0.27,0.34,0.43)
df<-df%>%dplyr::mutate(Bucket=if_else(between(Motiv,-.14999,.15),"A",if_else(between(Motiv,-.40,-.150001) | between(Motiv,.1501,.4),'B',-.64999990,-.40001) | between(Motiv,.40001,.65),"C",-.8999,-.650001) | between(Motiv,.650001,.9),"D",-1.14999,-.90001) | between(Motiv,.90001,1.15),"E",-1.39999,-1.150001) | between(Motiv,1.150001,1.4),"F",-1.64999,-1.40001) | between(Motiv,1.40001,1.65),"G",-1.9,-1.650001) | between(Motiv,1.650001,1.9),"H",if_else(Motiv< (-1.90)| Motiv>1.9,"I",'J'))))))))))
我的输出是:问题是当--65应该是C时J在哪里
df<-data.frame(Motiv=c(-0.27,0.43),Bucket=c( B,B,C,A,D,J,E,F,C)
解决方法
首先,我建议您远离嵌套的if_else
函数。 dplyr
具有case_when
函数,很好地满足了这一需求。
第二,您的代码正在执行预期的操作,概述的窗口未捕获-.65。见下文:
library(dplyr)
#DF taken from question
df<-data.frame(Motiv = c(-0.27,-0.34,-0.48,-0.546,-0.41,-0.39,-0.3,-0.44,-0.46,-0.3725,-0.16,-0.194,-0.105,-0.1,-0.0680000000000001,0.0600000000000001,0.04,0.0299999999999998,-0.27,-0.7,-0.65,-0.67,-0.55,-0.51,-0.4,-0.47,-0.38,-0.31,-0.42,-0.45,-0.53,-0.83,-0.94,-1.086,-1.07,-1.03,-1.05,-1.13,-1.33,-1.37,-1.14,-0.96,-0.87,-0.77,-0.64,-0.57,-0.12,-0.11,-0.19,-0.2,-0.22,0.0499999999999998,0.19,0.27,0.34,0.43))
#OP code done with case_when - will reproduce the error
df$check <- case_when(between(df$Motiv,-.14999,.15) ~ "A",between(df$Motiv,-.40,-.150001) | between(df$Motiv,.1501,.4) ~ 'B',-.64999990,-.40001) | between(df$Motiv,.40001,.65) ~ "C",-.8999,-.650001) | between(df$Motiv,.650001,.9) ~ "D",#add the rest
TRUE ~ 'J')
#output (which is J)
df[df$Motiv == -.65,]
如果要捕获-.65,请更改C的值:
#updated to produced expected answer
df$check <- case_when(between(df$Motiv,-.65,.65) ~"C",#need to capture -.65
between(df$Motiv,#add the rest
TRUE ~ 'J')
#output (which is C)
df[df$Motiv == -.65,]
,
进一步简化:
df$check <- as.character(
cut(abs(df$Motiv),c(0,0.15,0.4,0.65,0.9,1.15,1.4,1.65,1.9,Inf),c("A","B","C","D","E","F","G","I","J"))
)
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。