首页 > 解决方案 > 使用赋值运算符在 R 的 for 循环中创建多个 df

问题描述

我经常使用纵向数据集,汇总数据并将报告与汇总数据并排格式放在一起。为此,我通常会为相关年份运行一段代码,为每一年创建一个数据框,然后使用 bind_cols 将数据放在一起。

我希望使用 for 循环,所以我不需要每年修改代码。我试图在运行循环时使用赋值运算符创建多个数据框。这是我的尝试不起作用:

d1 <- data.frame(Year = c(2019, 2019, 2019, 2018, 2018),
                 Group = c("a", "b", "b", "a", "c"))

years <- c(2019, 2018)


for (i in years){
  df <- filter(d1$Year == i) %>%
        group_by(Group) %>%
        summarise(n = n()) %>%
        rename(paste0("n_", i) = n)

  dat[[i]] <- df
}

任何援助将不胜感激。

标签: r

解决方案


  d1 <- data.frame(Year = c(2019, 2019, 2019, 2018, 2018),
                     Group = c("a", "b", "b", "a", "c"))

  years <- c(2019, 2018)


  for (i in years){

  df = d1 %>%
    filter(d1$Year == i) %>%
    group_by(Group) %>%
    summarize(now = n())

  assign(paste0("df_", i),df)
}

推荐阅读