我使用 mtcars 数据集来说明我的问题。
例如,我想将数据子集到 4 缸汽车。我可以这样做:
mtcars %>% filter(cyl == 4)
在我的工作中,我需要传递一个字符串变量作为我的列名。例如:
var <- 'cyl'
mtcars %>% filter(var == 4)
我也做了:
mtcars %>% filter(!!var == 4)
在这两种情况下,我都得到了空数据框。
!!
or UQ
评估变量,所以mtcars %>% filter(!!var == 4)
是相同的mtcars %>% filter('cyl' == 4)
其中条件始终评估为 false;您可以通过打印来证明这一点!!var
在过滤器函数中:
mtcars %>% filter({ print(!!var); (!!var) == 4 })
# [1] "cyl"
# [1] mpg cyl disp hp drat wt qsec vs am gear carb
# <0 rows> (or 0-length row.names)
评估var
to the cyl
列,您需要转换var
到一个符号cyl
首先,然后评估符号cyl
到一列:
Using rlang
:
library(rlang)
var <- 'cyl'
mtcars %>% filter((!!sym(var)) == 4)
# mpg cyl disp hp drat wt qsec vs am gear carb
#1 22.8 4 108.0 93 3.85 2.320 18.61 1 1 4 1
#2 24.4 4 146.7 62 3.69 3.190 20.00 1 0 4 2
#3 22.8 4 140.8 95 3.92 3.150 22.90 1 0 4 2
# ...
Or use as.symbol/as.name
来自baseR:
mtcars %>% filter((!!as.symbol(var)) == 4)
mtcars %>% filter((!!as.name(var)) == 4)
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)