用函数替换多个`summaryize`语句

hua*_*uan 4 r function summarize tidyverse

我目前正在重复很多代码,因为summarize对于不同的组,我需要始终使用相同的列。如何通过只编写一次summarize函数(始终相同)来有效地做到这一点,但是要group_by逐个定义输出名称和参数?

一个最小的例子:

col1 <- c("UK", "US", "UK", "US")
col2 <- c("Tech", "Social", "Social", "Tech")
col3 <- c("0-5years", "6-10years", "0-5years", "0-5years")
col4 <- 1:4
col5 <- 5:8

df <- data.frame(col1, col2, col3, col4, col5)

result1 <- df %>% 
  group_by(col1, col2) %>% 
  summarize(sum1 = sum(col4, col5))

result2 <- df %>% 
  group_by(col2, col3) %>% 
  summarize(sum1 = sum(col4, col5))

result3 <- df %>% 
  group_by(col1, col3) %>% 
  summarize(sum1 = sum(col4, col5))
Run Code Online (Sandbox Code Playgroud)

zx8*_*754 5

使用combn

combn(colnames(df)[1:3], 2, FUN = function(x){
  df %>% 
    group_by(.dots = x) %>% 
    summarize(sum1 = sum(col4, col5))
  }, simplify = FALSE)
Run Code Online (Sandbox Code Playgroud)