r - mutate_impl(.data,dots)评估错误: object not found

标签 r dplyr purrr

我有一些工作代码。我必须更新 R(并再次安装所有软件包),当我尝试再次运行代码时遇到了困难。这是一个玩具示例:

工作代码

# get cyl column
mtcars %>% dplyr::select(cyl)
# add 1 to all numeric
mtcars %>% dplyr::mutate_if(is.numeric, ~.+1)


但是,当我尝试划分 cyl 列的所有数字列时,我做不到。

mtcars %>% mutate_if(is.numeric, ~./cyl)
Error in mutate_impl(.data, dots) : 
  Evaluation error: object 'cyl' not found.

顺便说一下......这有效

mtcars %>% mutate_if(is.numeric, ~./mtcars$cyl)

由于某种原因,mutate_if 找不到该列(尽管 select 找到了)。 purrr 包中的 map_if 具有相同的行为。

最佳答案

尝试添加funs()

library(dplyr)

mtcars %>% 
  mutate_if(is.numeric, funs(./cyl))
#>         mpg cyl  disp  hp drat    wt  qsec vs am gear carb
#> 1  3.500000   1 160.0 110 3.90 2.620 16.46  0  1    4    4
#> 2  3.500000   1 160.0 110 3.90 2.875 17.02  0  1    4    4
#> 3  5.700000   1 108.0  93 3.85 2.320 18.61  1  1    4    1
#> 4  3.566667   1 258.0 110 3.08 3.215 19.44  1  0    3    1
#> 5  2.337500   1 360.0 175 3.15 3.440 17.02  0  0    3    2
#> 6  3.016667   1 225.0 105 2.76 3.460 20.22  1  0    3    1
#> 7  1.787500   1 360.0 245 3.21 3.570 15.84  0  0    3    4
#> 8  6.100000   1 146.7  62 3.69 3.190 20.00  1  0    4    2
#> 9  5.700000   1 140.8  95 3.92 3.150 22.90  1  0    4    2
#> 10 3.200000   1 167.6 123 3.92 3.440 18.30  1  0    4    4


mtcars %>% 
  mutate_if(is.numeric, funs(div = ./cyl))
#>     mpg cyl  disp  hp drat    wt  qsec vs am gear carb  mpg_div cyl_div
#> 1  21.0   6 160.0 110 3.90 2.620 16.46  0  1    4    4 3.500000       1
#> 2  21.0   6 160.0 110 3.90 2.875 17.02  0  1    4    4 3.500000       1
#> 3  22.8   4 108.0  93 3.85 2.320 18.61  1  1    4    1 5.700000       1
#> 4  21.4   6 258.0 110 3.08 3.215 19.44  1  0    3    1 3.566667       1
#> 5  18.7   8 360.0 175 3.15 3.440 17.02  0  0    3    2 2.337500       1
#> 6  18.1   6 225.0 105 2.76 3.460 20.22  1  0    3    1 3.016667       1
#> 7  14.3   8 360.0 245 3.21 3.570 15.84  0  0    3    4 1.787500       1
#> 8  24.4   4 146.7  62 3.69 3.190 20.00  1  0    4    2 6.100000       1
#> 9  22.8   4 140.8  95 3.92 3.150 22.90  1  0    4    2 5.700000       1
#> 10 19.2   6 167.6 123 3.92 3.440 18.30  1  0    4    4 3.200000       1
#>    disp_div   hp_div  drat_div    wt_div qsec_div    vs_div    am_div
#> 1  26.66667 18.33333 0.6500000 0.4366667 2.743333 0.0000000 0.1666667
#> 2  26.66667 18.33333 0.6500000 0.4791667 2.836667 0.0000000 0.1666667
#> 3  27.00000 23.25000 0.9625000 0.5800000 4.652500 0.2500000 0.2500000
#> 4  43.00000 18.33333 0.5133333 0.5358333 3.240000 0.1666667 0.0000000
#> 5  45.00000 21.87500 0.3937500 0.4300000 2.127500 0.0000000 0.0000000
#> 6  37.50000 17.50000 0.4600000 0.5766667 3.370000 0.1666667 0.0000000
#> 7  45.00000 30.62500 0.4012500 0.4462500 1.980000 0.0000000 0.0000000
#> 8  36.67500 15.50000 0.9225000 0.7975000 5.000000 0.2500000 0.0000000
#> 9  35.20000 23.75000 0.9800000 0.7875000 5.725000 0.2500000 0.0000000
#> 10 27.93333 20.50000 0.6533333 0.5733333 3.050000 0.1666667 0.0000000

reprex package于2018年10月9日创建(v0.2.1.9000)

关于r - mutate_impl(.data,dots)评估错误: object not found,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52730562/

相关文章:

r - 如何计算字符串中重复字符的实例?

r - 多个组的多个响应的方差分析不是公式的一部分

r - 如何在所有方面保留或删除 geom_tile 的灰色边距?

r - 按多个组计算跨多列的最大值

r - purrr + dplyr NSE 问题在用户编写的函数中

r - 在R中生成结合字母和数字序列的字符串

r - 如何删除两列中以相反顺序包含相同对的行

r - dplyr - 多个汇总函数

r - 如何使用 purrr 和 tidyr 修改嵌套数据框中的列类型

r - purrr::map 相当于 dplyr::do