import openpyxl # 定义常量 apply_file = '申请名单.xlsx' summary_file = '汇总表.xlsx' apply_sheet_name = 'Sheet1' summary_sheet_name = 'Sheet1' try: # 使用with语句,确保工作簿在使用完后能够自动关闭 with openpyxl.load_workbook(apply_file, data_only=True) as wb_apply, openpyxl.load_workbook(summary_file) as wb_summary: # 获取申请表Sheet1和汇总表Sheet1 apply_sheet = wb_apply[apply_sheet_name] summary_sheet = wb_summary[summary_sheet_name] # 获取汇总表Sheet1的最大行数,并加1得到下一行的行号 next_row = summary_sheet.max_row + 1 # 从申请表Sheet1复制数据到汇总表Sheet1的下一行 for i, row in enumerate(apply_sheet.iter_rows(min_row=2, values_only=True), start=next_row): summary_sheet.append(row) # 保存汇总表工作簿 wb_summary.save(summary_file) except Exception as e: print(f"出现异常:{e}")
时间: 2023-07-16 14:12:31 浏览: 95
Python 解决pandas.to-excel()函数覆盖原有Sheet页的问题 Python源码
这段代码是一个Python脚本,用于将一个Excel文件中的数据复制到另一个Excel文件中的指定工作表中。其中使用了openpyxl库来处理Excel文件。具体实现步骤如下:
1. 定义了两个常量,分别表示申请名单Excel文件和汇总表Excel文件的文件名以及要操作的工作表的名称。
2. 使用with语句打开申请名单Excel文件和汇总表Excel文件,加载工作簿对象,并使用data_only参数确保在读取单元格时获取的是单元格的值而不是公式。
3. 获取申请表Sheet1和汇总表Sheet1的工作表对象。
4. 获取汇总表Sheet1的最大行数,并加1得到下一行的行号。
5. 使用iter_rows方法迭代申请表Sheet1中除第一行外的所有行,同时使用values_only参数确保获取的是单元格的值而不是单元格对象。
6. 将每一行的数据追加到汇总表Sheet1的下一行。
7. 保存汇总表工作簿。
8. 如果出现异常,则打印异常信息。
需要注意的是,这段代码只能处理Excel文件中的一个工作表,且申请表Sheet1和汇总表Sheet1中的列数和列名必须完全相同。如果要处理多个工作表或者不同列数和列名的工作表,需要进行相应的修改。
阅读全文