如何使用 openpyxl 将现有工作簿工作表添加到另一个现有工作簿?



我正在尝试创建一个包含 excel 文件列表的第一页的新 excel。

我尝试了以下内容,但当然第wb.create_sheet(sheet)行不起作用。

wb = Workbook('new.xlsx')
for i in range(len(file_list)):
excel = load_workbook(file_list[i], read_only=False)
sheet = excel[excel.sheetnames[0]]
sheet.Name = tab_names_list[i]
wb.create_sheet(sheet)

wb.save('new.xlsx')

同时,将wb.create_sheet(sheet)替换为wb.copy_worksheet(sheet)会产生错误ValueError: Cannot copy worksheets in read-only or write-only mode

这可能不适合您,但这是我在类似应用程序中使用的。它确实需要熊猫数据帧,我不确定您是否正在使用它们。

file_list = [file_1, file_2]
sheet_names = ['file1_name', 'file2_name']
writer = pd.ExcelWriter("workbook_name.xlsx", engine='xlsxwriter')
for file, s_names in zip(file_list, sheet_names):
file.to_excel(writer, sheet_name=s_names)
writer.save()

最新更新