Suministro de múltiples grupos de variables a una función para argumentos dplyr en el cuerpo
Aquí están los datos:
library(tidyverse)
data <- tibble::tribble(
~var1, ~var2, ~var3, ~var4, ~var5,
"a", "d", "g", "hello", 1L,
"a", "d", "h", "hello", 2L,
"b", "e", "h", "k", 4L,
"b", "e", "h", "k", 7L,
"c", "f", "i", "hello", 3L,
"c", "f", "i", "hello", 4L
)
y los vectores, quiero usar:
filter_var <- c("hello")
groupby_vars1 <- c("var1", "var2", "var3")
groupby_vars2 <- c("var1", "var2")
joinby_vars1 <- c("var1", "var2")
joinby_vars2 <- c("var1", "var2", "var3")
Los vectores segundo y quinto y tercero y cuarto son iguales, pero suponga que son diferentes y consérvelos como vectores diferentes.
Ahora quiero crear una función genérica donde pueda tomar datos y estos vectores para obtener los resultados.
my_fun <- function(data, filter_var, groupby_vars1,groupby_vars2, joinby_vars1, joinby_vars2) {
data2 <- data %>% filter(var4 == filter_var)
data3 <- data2 %>%
group_by(groupby_vars1) %>%
summarise(var6 = sum(var5))
data4 <- data3 %>%
ungroup() %>%
group_by(groupby_vars2) %>%
summarise(avg = mean(var6,na.rm = T))
data5 <- data3 %>% left_join(data4, by = joinby_vars1)
data6 <- data %>% left_join(data5, by = joinby_vars2)
}
El problema es suministrar múltiples vectores de múltiples variables a una función para usar como argumentos dplyr en el cuerpo. Traté de buscar en lahttp: //dplyr.tidyverse.org/articles/programming.htm, pero no pudo resolver el problema anterior.