如何将三个点参数传递给dplyr funs

时间:2017-02-28 08:46:37

标签: r dplyr

假设数据集中有一个名为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;

2 个答案:

答案 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