我正在尝试在本地函数中使用 dplyr 的 group_by,例如:
testFunction <- function(df, x) {
df %>%
group_by(x) %>%
summarize(mean.Petal.Width = mean(Petal.Width))
}
testFunction(iris, Species)
我得到一个错误“...未知变量分组依据:x” 我试过 group_by_ 它给了我整个数据集的摘要。 有人知道我该如何解决这个问题吗?
提前致谢!
最佳答案
这是使用来自 dplyr
的新 enquo
的一种方法,其中 enquo
获取字符串并转换为 quosure
在 group_by
、mutate
、 中通过取消引号(
等UQ
或 !!
)进行评估总结
library(dplyr)
testFunction <- function(df, x) {
x <- enquo(x)
df %>%
group_by(!! x) %>%
summarize(mean.Petal.Width = mean(Petal.Width))
}
testFunction(iris, Species)
# A tibble: 3 x 2
# Species mean.Petal.Width
# <fctr> <dbl>
#1 setosa 0.246
#2 versicolor 1.326
#3 virginica 2.026
关于r - 在函数中使用 dplyr group_by,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44659943/