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

时间:2020-05-30 13:11:06

标签: python 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

1 个答案:

答案 0 :(得分:0)

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

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()