Python如何使用ExcelWriter写入现有工作表

Ham*_*med 5 python pandas xlsxwriter

我正在尝试使用ExcelWriter将一些信息写入/添加到包含多个工作表的工作簿中.我第一次使用该函数时,我正在创建包含一些数据的工作簿.在第二个调用中,我想在不同位置的工作簿中将一些信息添加到所有工作表中.

def Out_Excel(file_name,C,col): 
    writer = pd.ExcelWriter(file_name,engine='xlsxwriter')
    for tab in tabs:    # tabs here is provided from a different function that I did not write here to keep it simple and clean
        df = DataFrame(C)    # the data is different for different sheets but I keep it simple in this case
        df.to_excel(writer,sheet_name = tab, startcol = 0 + col, startrow = 0)
    writer.save()
Run Code Online (Sandbox Code Playgroud)

在主代码中,我使用不同的col调用此函数两次,以在不同位置打印出我的数据.

Out_Excel('test.xlsx',C,0)
Out_Excel('test.xlsx',D,10)
Run Code Online (Sandbox Code Playgroud)

但问题是这样做输出只是函数的第二次调用,就像函数覆盖整个工作簿一样.我想我需要加载本案例中已经存在的工作簿?有帮助吗?

Ste*_*fan 11

使用load_bookopenpyxl-见xlsxwriteropenpyxl文档:

import pandas as pd
from openpyxl import load_workbook

book = load_workbook('test.xlsx')
writer = pd.ExcelWriter('test.xlsx', engine='openpyxl') 
writer.book = book
writer.sheets = dict((ws.title, ws) for ws in book.worksheets)

df.to_excel(writer, sheet_name='tab_name', other_params)

writer.save()
Run Code Online (Sandbox Code Playgroud)

  • @Stefan我刚刚[发布了一个问题](/sf/ask/3165417321/),最近偶然发现了这篇文章。您能解释一下 `writer.book = book` 正在做什么以及*为什么*这允许您写入现有的工作簿吗? (2认同)

T.C*_*tor 10

Pandas 0.24.0 版添加了mode关键字,它允许您附加到 excel 工作簿,而无需跳过我们过去必须做的工作。仅用于mode='a'将工作表附加到现有工作簿。

文档

with ExcelWriter('path_to_file.xlsx', mode='a') as writer:
     df.to_excel(writer, sheet_name='Sheet3')
Run Code Online (Sandbox Code Playgroud)