df = data.frame(
A = c(1, 4, 5, 13, 2),
B = c("Group 1", "Group 3", "Group 2", "Group 1", "Group 2"),
C = c("Group 3", "Group 2", "Group 1", "Group 2", "Group 3")
)
df %>%
group_by(B) %>%
summarise(val = mean(A))
df %>%
group_by(C) %>%
summarise(val = mean(A))
而不是为每个独特的集合编写新的代码块group_by
我想创建一个循环来迭代df
数据框并将结果保存到列表或数据框中。
我想看看特征的平均值如何A分布在各个特征上B and C,无需为数据集中的每个分类特征编写新的代码块。
我试过这个:
List_Of_Groups <- map_df(df, function(i) {
df %>%
group_by(!!!syms(names(df)[1:i])) %>%
summarize(newValue = mean(A))
})