请你帮助我好吗。
我已经尝试了很多组合,但没有任何效果。
这里的例子:
library(dplyr)
foo <- function(AA,x){
mn <- make.names(x)
mn <- enquo(mn)
filter(AA,mn==min(!!mn))
}
aa <- data.frame(A=c("a","b","c","d"), B.D = c(1,2,1,3))
foo(aa,"B D")
Run Code Online (Sandbox Code Playgroud)
输出是
Error: Base operators are not defined for quosures.
Do you need to unquote the quosure?
# Bad:
myquosure == rhs
# Good:
!!myquosure == rhs
Run `rlang::last_error()` to see where the error occurred.
Run Code Online (Sandbox Code Playgroud)
代替
filter(aa,B.D==min(B.D))
A B.D
1 a 1
2 c 1
Run Code Online (Sandbox Code Playgroud)
您能帮我使用我的函数获得所需的输出吗?
谢谢你。
约翰
使用{{ }}“拥抱”或“双卷曲”运算符稍微简单一点,但它期望变量名 raw 与字符串。
foo <- function(AA,x){
filter(AA, {{ x }} == min({{ x }}))
}
foo(aa, B.D) # or foo(aa, `B.D`)
A B.D
1 a 1
2 c 1
Run Code Online (Sandbox Code Playgroud)