r - 使用赋值运算符在 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
}
任何援助将不胜感激。
解决方案
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)
}
推荐阅读
- python - 如何解决 spyder 中 pyttsx3 模块的问题?
- javascript - 如何将事件监听器添加到 redux 表单
- asp.net-core - 如何查看 EntityFramework Core 生成的 SQL?
- wordpress - 如何检查“在档案中启用 AJAX 添加到购物车按钮”状态?
- grails - Grails 3.3.2 Spring Security CAS 不能通过负载均衡器工作,但可以通过部署在其上的内部服务器正常工作
- java - 在 Eclipse IDE 上的 Java 中,我在包行(类中的第一行)上收到错误
- gitlab - 如何在 Gitlab Markdown 中指定 Mermaid 配置?
- mysql - 在 MySQL 中添加外键时是否需要指定约束名称?
- spring - 保存后的 JPA 查询不返回数据库生成的字段
- c++ - 使用 C++ 在 LeetCode 中的 Pow(x,n)。地址消毒剂 33