首页 > 解决方案 > 通过带有“{{”运算符的环境变量隧道数据变量

问题描述

按照https://www.tidyverse.org/blog/2020/02/glue-strings-and-tidy-eval/中的示例

你如何将变量传递给这个函数?

library(tidyverse)
#> Warning: package 'tidyverse' was built under R version 3.6.2
#> Warning: package 'tidyr' was built under R version 3.6.2

mean_by <- function(data, by, var, prefix = "avg") {
  data %>%
    group_by({{ by }}) %>%
    summarise("{prefix}_{{ var }}" := mean({{ var }}, na.rm = TRUE))
}

mean_by(mtcars, by = cyl, var = mpg, prefix = "avg")
#> # A tibble: 3 x 2
#>     cyl avg_mpg
#>   <dbl>   <dbl>
#> 1     4    26.7
#> 2     6    19.7
#> 3     8    15.1

# Variables to pass into function
params <-  setdiff(colnames(mtcars) ,"mpg") 

# How do you pass a variables into this function? 
purrr::map(params, mean_by(mtcars, by = .x, var = mpg, prefix = "avg"))
#> Error: Column `.x` is unknown

reprex 包(v0.3.0)于 2020-02-19 创建

标签: rdplyrtidyverse

解决方案


使用.data带有列名的代词:

purrr::map(params, ~ mean_by(mtcars, by = .data[[.x]], var = mpg, prefix = "avg"))

推荐阅读