批量将不同的工作簿合并到同一个Excel文件

简介: 本文介绍如何使用Python的`pandas`库批量合并不同工作簿至同一Excel文件。通过模拟生成三个班级的成绩数据,分别保存为Excel文件,再将这些文件合并成一个包含所有班级成绩的总成绩单。步骤包括安装必要库、生成数据、保存与合并工作簿。

批量将不同的工作簿合并到同一个Excel文件

下面是一个示例,展示如何批量将不同的工作簿合并到同一个Excel文件,并生成模拟数据。我们将使用 Python 的 pandas 库来完成这个任务。具体步骤如下:

步骤 1: 安装必要的库

首先确保你已安装 pandasopenpyxl 库。如果没有安装,可以通过以下命令进行安装:

pip install pandas openpyxl

步骤 2: 模拟生成数据并保存为不同的工作簿

这段代码将生成三个不同的 Excel 文件,分别为“三年一班.xlsx”,“三年二班.xlsx”和“三年三班.xlsx”。

import pandas as pd
import numpy as np
import random


# 定义函数生成模拟数据
def create_class_data(class_name, num_students=10):
    data = {
   
        '姓名': [f"{random.choice(['张','赵','钱','孙', '李','刘','王','吴'])}{random.choice(['三','四','五','六','二','八','七'])}" for i in range(num_students)],
        '数学': np.random.randint(60, 100, size=num_students),
        '语文': np.random.randint(60, 100, size=num_students),
        '英语': np.random.randint(60, 100, size=num_students)
    }
    df = pd.DataFrame(data)
    df.to_excel(f'{class_name}.xlsx', index=False)

# 创建三个班级的数据
create_class_data('三年一班')
create_class_data('三年二班')
create_class_data('三年三班')

步骤 3: 合并工作簿到一个 Excel 文件

接下来,我们将上述生成的三个工作簿合并到一个名为“‘三年级总成绩单.xlsx’”的 Excel 文件中。

# 合并工作簿
excel_files = ['三年一班.xlsx', '三年二班.xlsx', '三年三班.xlsx']
combined_data = pd.DataFrame()

for file in excel_files:
    df = pd.read_excel(file)
    df['班级'] = file.split('.')[0]  # 添加班级列
    combined_data = pd.concat([combined_data, df], ignore_index=True)

# 保存合并后的数据到一个新的 Excel 文件
combined_data.to_excel('三年级总成绩单.xlsx', index=False)

总结

您现在可以运行上述代码片段。首先生成三个班级的成绩表,然后合并它们到一个总成绩单中。最后,您会在当前目录下看到一个名为“‘三年级总成绩单.xlsx’”的文件,里面包含了所有班级的成绩数据。

欢迎点赞、关注、收藏、转发!!!

相关文章
|
6天前
|
人工智能 自然语言处理 Java
FastExcel:开源的 JAVA 解析 Excel 工具,集成 AI 通过自然语言处理 Excel 文件,完全兼容 EasyExcel
FastExcel 是一款基于 Java 的高性能 Excel 处理工具,专注于优化大规模数据处理,提供简洁易用的 API 和流式操作能力,支持从 EasyExcel 无缝迁移。
54 9
FastExcel:开源的 JAVA 解析 Excel 工具,集成 AI 通过自然语言处理 Excel 文件,完全兼容 EasyExcel
|
1月前
|
Python
按条件将Excel文件拆分到不同的工作表
使用Python的pandas库,可以轻松将Excel文件按条件拆分到不同的工作表中。本文通过一个示例代码展示了如何生成一个包含总成绩表和三个班级表的Excel文件。代码首先创建了一个包含学生姓名、班级和各科成绩的数据框,然后按班级分组,将每个班级的数据分别写入不同的工作表。最后,生成的Excel文件将包含四个工作表,分别为总成绩表和三个班级的成绩表。
32 6
按条件将Excel文件拆分到不同的工作表
|
1月前
|
Python
按条件将Excel文件拆分到不同的工作表
使用Python的pandas库,可以轻松将Excel文件按条件拆分为多个工作表。本文通过一个具体示例,展示了如何根据学生班级将成绩数据拆分到不同的工作表中,并生成一个包含总成绩表和各班级成绩表的Excel文件。代码简洁明了,适合初学者学习和应用。
41 6
|
2月前
|
前端开发
实现Excel文件和其他文件导出为压缩包,并导入
实现Excel文件和其他文件导出为压缩包,并导入
35 1
|
2月前
|
存储 Java API
Java实现导出多个excel表打包到zip文件中,供客户端另存为窗口下载
Java实现导出多个excel表打包到zip文件中,供客户端另存为窗口下载
90 4
|
3月前
|
JavaScript 前端开发 数据处理
Vue导出el-table表格为Excel文件的两种方式
Vue导出el-table表格为Excel文件的两种方式
125 6
|
3月前
|
easyexcel Java UED
SpringBoot中大量数据导出方案:使用EasyExcel并行导出多个excel文件并压缩zip后下载
在SpringBoot环境中,为了优化大量数据的Excel导出体验,可采用异步方式处理。具体做法是将数据拆分后利用`CompletableFuture`与`ThreadPoolTaskExecutor`并行导出,并使用EasyExcel生成多个Excel文件,最终将其压缩成ZIP文件供下载。此方案提升了导出效率,改善了用户体验。代码示例展示了如何实现这一过程,包括多线程处理、模板导出及资源清理等关键步骤。
|
3月前
|
数据处理 Python
Python 高级技巧:深入解析读取 Excel 文件的多种方法
在数据分析中,从 Excel 文件读取数据是常见需求。本文介绍了使用 Python 的三个库:`pandas`、`openpyxl` 和 `xlrd` 来高效处理 Excel 文件的方法。`pandas` 提供了简洁的接口,而 `openpyxl` 和 `xlrd` 则针对不同版本的 Excel 文件格式提供了详细的数据读取和处理功能。此外,还介绍了如何处理复杂格式(如合并单元格)和进行性能优化(如分块读取)。通过这些技巧,可以轻松应对各种 Excel 数据处理任务。
265 16
|
3月前
|
JSON 数据格式
LangChain-20 Document Loader 文件加载 加载MD DOCX EXCEL PPT PDF HTML JSON 等多种文件格式 后续可通过FAISS向量化 增强检索
LangChain-20 Document Loader 文件加载 加载MD DOCX EXCEL PPT PDF HTML JSON 等多种文件格式 后续可通过FAISS向量化 增强检索
164 2
|
4月前
R Excel 文件
Excel 格式的文件主要是 xls 或 xlsx,这两种文件可以在 R 语言中导入 xlsx 库来实现直接的读取。
79 23