- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我认为如果我展示会更容易,问题是什么,所以我有这个数字数据
MoSold YrSold SalePrice OverallQual OverallCond
1 2 3 208500 7 5
2 5 2 181500 6 8
3 9 3 223500 7 5
4 2 1 140000 7 5
5 12 3 250000 8 5
6 10 4 143000 5 5
感谢 mutate_at 和嵌套的 ifelse,如果条件为真(列平均值高于 0.8),我想更改每一行,但是当我尝试使用此代码执行此操作时
data %>%
mutate_at(vars(MoSold, YrSold, SalePrice, OverallQual, OverallCond),
~(ifelse((mean(., na.rm = T)) > 4, log(.), .))) %>% head()
我得到以下数据,所有列都具有相同的值
MoSold YrSold SalePrice OverallQual OverallCond
1 0.6931472 3 12.24769 1.94591 1.609438
2 0.6931472 3 12.24769 1.94591 1.609438
3 0.6931472 3 12.24769 1.94591 1.609438
4 0.6931472 3 12.24769 1.94591 1.609438
5 0.6931472 3 12.24769 1.94591 1.609438
6 0.6931472 3 12.24769 1.94591 1.609438
如果条件为真,我想记录每一行的相应值,如果条件为假,则记录原始值
我知道一种解决方案是使用 for 循环,但我真的很喜欢使用 dplyr/tidyverse 的解决方案
提前致谢
我.
最佳答案
这个问题与用作 ifelse
的 test
的 mean
有关,这是一个单一的值,而 'yes', 'no ' 参数的长度不同,即逻辑表达式会导致单个 TRUE/FALSE,并且会通过回收"is"、“否”的第一个元素来复制整个长度
在这里,我们可以使用if/else
代替ifelse
library(dplyr)
data %>%
mutate_all(~ if(mean(., na.rm = TRUE) > 4) log(.) else .)
在 dplyr
1.0.0 中,一个选项是 mutate/across
data %>%
mutate(across(everything(),
~ if(mean(., na.rm = TRUE) > 4) log(.) else .))
# MoSold YrSold SalePrice OverallQual OverallCond
#1 0.6931472 3 12.24769 1.945910 1.609438
#2 1.6094379 2 12.10901 1.791759 2.079442
#3 2.1972246 3 12.31717 1.945910 1.609438
#4 0.6931472 1 11.84940 1.945910 1.609438
#5 2.4849066 3 12.42922 2.079442 1.609438
#6 2.3025851 4 11.87060 1.609438 1.609438
如果我们想使用ifelse
,复制单个逻辑值使所有'test'、'yes'、'no'长度相同
data %>%
mutate_at(vars(MoSold, YrSold, SalePrice, OverallQual, OverallCond),
~(ifelse(rep((mean(., na.rm = T)) > 4, n()), log(.), .)))
# MoSold YrSold SalePrice OverallQual OverallCond
#1 0.6931472 3 12.24769 1.945910 1.609438
#2 1.6094379 2 12.10901 1.791759 2.079442
#3 2.1972246 3 12.31717 1.945910 1.609438
#4 0.6931472 1 11.84940 1.945910 1.609438
#5 2.4849066 3 12.42922 2.079442 1.609438
#6 2.3025851 4 11.87060 1.609438 1.609438
data <- structure(list(MoSold = c(2L, 5L, 9L, 2L, 12L, 10L), YrSold = c(3L,
2L, 3L, 1L, 3L, 4L), SalePrice = c(208500L, 181500L, 223500L,
140000L, 250000L, 143000L), OverallQual = c(7L, 6L, 7L, 7L, 8L,
5L), OverallCond = c(5L, 8L, 5L, 5L, 5L, 5L)), class = "data.frame",
row.names = c("1",
"2", "3", "4", "5", "6"))
关于r - 向量化的 Mutate_at 和 ifelse 问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/62524812/
if () {}else if (){} else if (){} else if (){} else{} 我们是否需要至少有一个else {}? 最佳答案 不,不需要 else block 。 以下
如果为TRUE,我想从函数返回一个data.frame,否则使用return(ifelse(condition, mydf, NA)) 返回NA 但是, ifelse 会从 data.frame 中删
我有一个如下所示的数据框: dat <- data.frame(T1 = c('s', 's', 'm', 'l', 'm', 'xl'), T2 = c('s',
我有两个矩阵: mat <- matrix(1:6, 2, 3) mat2 <- matrix(1:2, 2, 3) 和一个参数 a <- 1 使用 ifelse , 是否可以在 a 时返回矩阵是一定
这个问题在这里已经有了答案: How to prevent ifelse() from turning Date objects into numeric objects (7 个答案) 关闭 7
而 R 的 ifelse非常方便,它确实有一个特别的缺点:在通话中 ifelse(test, yes, no) yes的所有元素和 no被评估,即使是那些将被扔掉的。 如果您在复杂的数值练习中使用它,
我有一个数据框(示例数据): id dat$ex1 + dat$ex2, 5, dat$ex) 此处,ex1 是最大值,其次是 ex1 和 ex2。 对于 id 2,它应该是: dat$ex da
我从 ifelse() 得到了一个完全出乎意料的结果,如果能解释原因,我将不胜感激。请参阅底部的可重现数据。 split_ratio = 0.8 target_label = "DV" trainin
我希望将两个函数之一应用于向量元素。选择使用哪个函数是基于向量的值。 具体来说:假设所有日期都在 1919 年和 2018 年之间,假设您想将用两位数字编码的年份(如 '07' 表示 '2007' 和
我仍然觉得 R 中的 ifelse 结构有点困惑,我有以下数据框: df <- structure(list(snp = structure(1:11, .Label = c("AL0009", "A
运行后我得到了意想不到的结果: test = c(rep(FALSE, 2), rep(TRUE, 6)) ifelse(test, c(1:8)[test], 1) [1] 1 1 5 6 7
这很奇怪:R的ifelse()似乎做了一些(不需要的)强制转换: 可以说我有一个时间戳向量(可能是NA),并且NA值应与现有日期区别对待,例如,只需忽略即可: formatString = "%Y-%
想法是使用可管理的方法从一些表中定义规则: library(data.table) a % print() lb[a, on = .(rule, bool), nomatch = 0L][
我有两个向量: ab 1 if ab,1,0) 但我不确定如何合并a和b相等的情况。 最佳答案 如何添加另一个ifelse: ifelse(a>b, 1, ifelse(a==b, sample(1:
基本上在 SAS 中,我可以在没有 else 的情况下执行 if 语句。例如: if species='setosa' then species='regular'; 不需要别的。 如何在R中做到这一
如果运行此命令,则会获得有关财务报表的信息 library(RJSONIO) data<-fromJSON("http://www.registeruz.sk/cruz-public/api/ucto
我有两个如下变量: var a = "active" //[two possible value active/inactive] var b = "inactive" //[three possi
我仍在学习 R,并遇到了一些超出我理解的事情。我花了大约 2 个小时试图自己解决这个问题,但失败了:-( 。 我有一个 data.frame(例如,让我们考虑一下鸢尾花),我想使用 ifelse 对其
我从 ifelse 函数中得到了意想不到的结果: vector <- factor(c('x', 'x', 'y', 'z'), levels = c('x', 'y', 'z')) ifelse(c
我有一个非常大的数据框(大约 100 行,200 列)。我的数据子集如下所示: example = 100,则 3 个数字 我知道对特定列执行类似的操作: example$Value1 = 100)
我是一名优秀的程序员,十分优秀!