% tibble() %>% magrittr::set_colnames("vars1") %>-6ren">
gpt4 book ai didi

r - 如何在 purrr 中使用 rlang

转载 作者:行者123 更新时间:2023-12-04 11:02:44 27 4
gpt4 key购买 nike

我想获得 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/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com