使用整齐的评估语义将一个字符向量分组为group_by [英] group_by by a vector of characters using tidy evaluation semantics

查看:100
本文介绍了使用整齐的评估语义将一个字符向量分组为group_by的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我曾经使用group_by_

library(dplyr)
group_by <- c('cyl', 'vs')
mtcars %>% group_by_(.dots = group_by) %>% summarise(gear = mean(gear))

,但现在不推荐使用group_by_.我不知道如何使用整洁的评估框架.

but now group_by_ is deprecated. I don't know how to do it using the tidy evaluation framework.

推荐答案

group_bygroup_by_at变体:

library(dplyr)
group_by <- c('cyl', 'vs')
mtcars %>% group_by_at(group_by) %>% summarise(gear = mean(gear))

上面是广义的简化版本:

Above it's simplified version of generalized:

mtcars %>% group_by_at(vars(one_of(group_by))) %>% summarise(gear = mean(gear))

vars内部,您可以使用任何dplyr方式选择变量:

inside vars you could use any dplyr way of select variables:

mtcars %>%
    group_by_at(vars(
        one_of(group_by) # columns from predefined set
        ,starts_with("a") # add ones started with a
        ,-hp # but omit that one
        ,vs # this should be always include
        ,contains("_gr_") # and ones with string _gr_
    )) %>%
    summarise(gear = mean(gear))

这篇关于使用整齐的评估语义将一个字符向量分组为group_by的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆