无法将文件复制到xlsm文件

时间:2019-06-06 16:08:40

标签: python excel-vba openpyxl

我想使用openpyxl python将工作表从几个excel文件复制到另一个xlsm工作簿。我使用了How to write to an existing excel file without overwriting data (using pandas)?

中的代码

但是我无法将df写入xlsm文件,它可以与.xlsx文件正常工作

def append_df_to_excel(filename, df, sheet_name='Sheet1', startrow=None,
                       truncate_sheet=False, 
                       **to_excel_kwargs):


    Returns: None

    from openpyxl import load_workbook

    import pandas as pd

   if 'engine' in to_excel_kwargs:
        to_excel_kwargs.pop('engine')

    writer = pd.ExcelWriter(filename, engine='openpyxl')


    try:
        FileNotFoundError
    except NameError:
        FileNotFoundError = IOError


    try:
       writer.book = load_workbook(filename)
       if startrow is None and sheet_name in writer.book.sheetnames:
            startrow = writer.book[sheet_name].max_row

        if truncate_sheet and sheet_name in writer.book.sheetnames:
            # index of [sheet_name] sheet
            idx = writer.book.sheetnames.index(sheet_name)

            writer.book.remove(writer.book.worksheets[idx])
            writer.book.create_sheet(sheet_name, idx)
        writer.sheets = {ws.title:ws for ws in writer.book.worksheets}
    except FileNotFoundError:
        # file does not exist yet, we will create it
        pass

    if startrow is None:
        startrow = 0

    df.to_excel(writer, sheet_name, startrow=startrow, **to_excel_kwargs)


    # save the workbook
    writer.save()

append_df_to_excel('E:\test.xlsm', all_data, sheet_name='sample_test', index=False, startrow=7)

还可以使用宏从excel运行Jupyter笔记本代码吗?

0 个答案:

没有答案