假设数据集中有一个名为GROUP的列:
summ <- function(dataset, FUN = mean, …) {
dataset <- dataset %>% group_by(GROUP) %>% summarise_each(funs(FUN)) %>% arrange(GROUP)
data.frame(dataset)
}
dataset<- data.frame(a = c(1, 2, 3, NA), GROUP = c(1, 2, 2, 1)
summ(dataset, na.rm = TRUE)
GROUP a
1 1 NA
2 2 2.5
在计算结果之前,所需的行为是将na.rm = TRUE参数传递给mean函数以删除NA。预期的输出是:
GROUP a
1 1 1
2 2 2.5
我怎样才能将...参数传递给乐趣?我试过了
summarise_each(funs(FUN(., …)))
和
FUN <- match.fun(FUN)
funs_(dots = substitute(FUN), args = list(...))
和
summarise_each(funs_(dots = FUN, args = list(…)))
最后一个示例在UseMethod中引发错误&#39;错误(&#34; as.lazy_dots&#34;)&#39;
答案 0 :(得分:0)
在你的函数中,创建一个新函数,它是包含点 - 点的FUN
函数:
summ <- function(dataset, FUN = mean, ...) {
FUN2 = function(x){FUN(x,...)}
dataset <- dataset %>% group_by(GROUP) %>% summarise_each(funs(FUN2)) %>% arrange(GROUP)
data.frame(dataset)
}
> summ(dataset,na.rm=TRUE)
GROUP a
1 1 1.0
2 2 2.5
> summ(dataset)
GROUP a
1 1 NA
2 2 2.5
>
答案 1 :(得分:0)
将点作为列表捕获,并使用substitute
我们可以正确使用funs_
:
summ <- function(dataset, FUN = mean, ...) {
dots <- list(...)
FUN <- substitute(FUN)
dataset %>%
group_by(GROUP) %>%
summarise_each(funs_(FUN, args = dots)) %>%
arrange(GROUP)
}
summ(dataset, na.rm = TRUE)
# A tibble: 2 × 2 GROUP a <dbl> <dbl> 1 1 1.0 2 2 2.5