r - 如何在 purrr 中使用 rlang

标签 r tidyverse purrr rlang

我想获得 2 个 data.frames,按列进行不同分组

c("hp", "cyl") %>% 
  tibble() %>% 
  magrittr::set_colnames("vars1") %>% 
  mutate(data = map(vars1,~mtcars %>% as_tibble)) %>% 
  mutate( res = map2(data,vars1,function(x,y){
    x %>% 
      group_by(!!sym(y))
  }))

我无法意识到 !!sym(y)
有什么问题 感谢您的建议

最佳答案

我们可以使用可以接受字符串参数的group_by_at

library(tidyverse)

c("hp", "cyl") %>% 
  tibble() %>% 
  magrittr::set_colnames("vars1") %>% 
  mutate(data = map(vars1,~mtcars %>% as_tibble)) %>% 
  mutate(res = map2(data,vars1,function(x,y){
    x %>% 
      group_by_at(y)
  }))

# A tibble: 2 x 3
#  vars1 data               res               
#  <chr> <list>             <list>            
#1 hp    <tibble [32 × 11]> <tibble [32 × 11]>
#2 cyl   <tibble [32 × 11]> <tibble [32 × 11]>

如果我们将其作为独立函数并将其应用到 map2 中,当前的解决方案就可以工作

sym_fun <- function(x, y) {
  x %>%  group_by(!!sym(y))
}

c("hp", "cyl") %>% 
  tibble() %>% 
  magrittr::set_colnames("vars1") %>% 
  mutate(data = map(vars1,~mtcars %>% as_tibble)) %>% 
  mutate(res = map2(data,vars1,sym_fun))

关于r - 如何在 purrr 中使用 rlang,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58693641/

相关文章:

r - 使用 tidyverse 标记 R 中子集的顶部条目

将共享数据列中的多个值重新编码/替换为跨数据帧的单个值

r - 观星表中的因变量标签

r - 如何为因子变量的每个级别应用函数?

r - 列名上的整洁评估映射

r - 计算满足 "less than"过滤器值序列的行数

html - 使用标签在 Shiny - R 中创建下拉菜单

r - 带有图像的多个 Kable 表

r - 在 RStudio 中加载 Tidyverse 时出现问题

R:将嵌套的for循环转换为应用函数