首頁 >後端開發 >Python教學 >如何使用 Pandas 將資料附加到現有 Excel 工作表而不覆蓋?

如何使用 Pandas 將資料附加到現有 Excel 工作表而不覆蓋?

DDD
DDD原創
2024-12-25 05:57:13796瀏覽

How Can I Append Data to an Existing Excel Sheet Using Pandas Without Overwriting?

使用Pandas 寫入現有Excel 檔案而不覆蓋資料

使用pandas 寫入Excel 檔案而不覆蓋現有資料時,當您想要新增將新工作表新增到先前建立的文件中。但是,pandas 的預設行為會覆蓋整個文件,刪除任何現有的選項卡。為了解決這個問題,我們可以利用 openpyxl 函式庫。

Openpyxl 與 Pandas ExcelWriter 整合

Pandas 利用 openpyxl 來處理 XLSX 檔。透過將 ExcelWriter 中的“engine”參數明確設定為“openpyxl”,我們可以對檔案內容進行更精細的控制。

程式碼實作

import pandas
from openpyxl import load_workbook

book = load_workbook('Masterfile.xlsx')
writer = pandas.ExcelWriter('Masterfile.xlsx', engine='openpyxl')
writer.book = book

# Populate a dictionary of existing sheets for ExcelWriter
writer.sheets = dict((ws.title, ws) for ws in book.worksheets)

# Write to the desired sheet without overwriting
data_filtered.to_excel(writer, "Main", cols=['Diff1', 'Diff2'])

writer.save()

在這個程式碼中:

  • 我們使用 openpyload 載入現有的 Excel 檔案xl_workbook。
  • 我們建立一個 Pandas ExcelWriter 對象,並將“engine”參數設為“openpyxl”,將其連結到我們載入的工作簿。
  • 我們使用現有工作表填入 writer.sheets 字典防止 ExcelWriter 建立新的「主」工作表。
  • 我們將所需的資料寫入「主」工作表而不覆蓋工作簿中的任何其他部分。
  • 最後,我們儲存更新的工作簿以保留變更。

以上是如何使用 Pandas 將資料附加到現有 Excel 工作表而不覆蓋?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn