搜尋
首頁後端開發Python教學如何使用 Pandas 將新工作表新增至現有 Excel 檔案?

How to Add New Sheets to an Existing Excel File Using Pandas?

使用Pandas 在現有Excel 檔案中產生新工作表

在Python 中處理Excel 資料時,使用者可能會遇到將新工作表儲存到現有Excel 文件的挑戰。本指南提供了使用 Pandas 函式庫的解決方案,涵蓋了「xlsxwriter」引擎的限制和「openpyxl」引擎的實作。

理解問題

在給定的程式碼中,使用者建立一個包含兩個工作表「x1」和「x2」的 Excel 檔案。但是,嘗試新增工作表“x3”和“x4”會覆蓋原始資料。發生這種情況的原因是「xlsxwriter」引擎僅將資料儲存到新檔案或覆蓋現有檔案。

使用「openpyxl」引擎的解決方案

要在新增工作表時保留現有數據,請使用「openpyxl」引擎。以下程式碼示範了這個方法:

<code class="python">import pandas as pd
import numpy as np
from openpyxl import load_workbook

path = r"C:\Users\fedel\Desktop\excelData\PhD_data.xlsx"

book = load_workbook(path)  # Load the existing Excel file
writer = pd.ExcelWriter(path, engine='openpyxl')  # Create a Pandas writer connected to the workbook
writer.book = book  # Assign the workbook to the Pandas writer

x3 = np.random.randn(100, 2)
df3 = pd.DataFrame(x3)

x4 = np.random.randn(100, 2)
df4 = pd.DataFrame(x4)

df3.to_excel(writer, sheet_name='x3')  # Write the new dataframes to the existing file
df4.to_excel(writer, sheet_name='x4')

writer.close()  # Save the changes to the file</code>

說明

  1. 載入現有Excel 檔案:此行使用下列指令將現有Excel 檔案讀取取到工作簿物件中load_workbook 函數。
  2. 建立 Pandas writer:這裡使用 engine='openpyxl' 參數建立一個 Pandas ExcelWriter,該參數指定使用「openpyxl」引擎。
  3. 將工作簿指派給 writer:writer.book 屬性設定為載入的工作簿對象,將 Pandas writer 連結到現有檔案。
  4. 產生新檔案dataframes:與原始程式碼類似,建立新的資料幀(「x3」和「x4」)。
  5. 寫入新資料幀:新資料幀儲存到現有檔案中使用 to_excel 方法,指定工作表名稱(“x3”和“x4”)。
  6. 儲存變更:最後,Pandas writer 所做的變更將儲存到 Excel 檔案中呼叫 writer.close() 方法。

WebSocket、ws 和Dict

在給定連結的建議程式碼中:

  • WebSocket (ws):指指🎜>
  • WebSocket (ws)
  • :指指的是載入的工作簿中的每個工作表。
  • ws.title
  • :代表工作簿中特定工作表的名稱。
  • Dict
:程式碼使用字典在工作表名稱和工作表物件之間建立映射。這允許 Pandas 編寫器存取載入的工作簿中的特定工作表。

以上是如何使用 Pandas 將新工作表新增至現有 Excel 檔案?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
說明列表和數組之間元素操作的性能差異。說明列表和數組之間元素操作的性能差異。May 06, 2025 am 12:15 AM

ArraySareBetterForlement-WiseOperationsDuetofasterAccessCessCessCessCessCessCessCessAndOptimizedImplementations.1)ArrayshaveContiguucuulmemoryfordirectAccesscess.2)列出sareflexible butslible butslowerduetynemicizing.3)

如何有效地對整個Numpy陣列進行數學操作?如何有效地對整個Numpy陣列進行數學操作?May 06, 2025 am 12:15 AM

在NumPy中进行整个数组的数学运算可以通过向量化操作高效实现。1)使用简单运算符如加法(arr 2)可对数组进行运算。2)NumPy使用C语言底层库,提升了运算速度。3)可以进行乘法、除法、指数等复杂运算。4)需注意广播操作,确保数组形状兼容。5)使用NumPy函数如np.sum()能显著提高性能。

您如何將元素插入python數組中?您如何將元素插入python數組中?May 06, 2025 am 12:14 AM

在Python中,向列表插入元素有兩種主要方法:1)使用insert(index,value)方法,可以在指定索引處插入元素,但在大列表開頭插入效率低;2)使用append(value)方法,在列表末尾添加元素,效率高。對於大列表,建議使用append()或考慮使用deque或NumPy數組來優化性能。

如何使Unix和Windows上的Python腳本可執行?如何使Unix和Windows上的Python腳本可執行?May 06, 2025 am 12:13 AM

tomakeapythonscriptexecutableonbothunixandwindows:1)addashebangline(#!/usr/usr/bin/envpython3)Andusechmod xtomakeitexecutableonix.2)onWindows,確保pytythonisinstalledandassionstalledandassociatedwith.pyfiles,oruseabatchfile(runun.batchfile(runitter)(rugitty.batt)

試圖運行腳本時,應該檢查一下是否會發現'找不到命令”錯誤?試圖運行腳本時,應該檢查一下是否會發現'找不到命令”錯誤?May 06, 2025 am 12:03 AM

當遇到“commandnotfound”錯誤時,應檢查以下幾點:1.確認腳本存在且路徑正確;2.檢查文件權限,必要時使用chmod添加執行權限;3.確保腳本解釋器已安裝並在PATH中;4.驗證腳本開頭的shebang行是否正確。這樣做可以有效解決腳本運行問題,確保編碼過程順利進行。

為什麼數組通常比存儲數值數據列表更高?為什麼數組通常比存儲數值數據列表更高?May 05, 2025 am 12:15 AM

ArraySareAryallyMoremory-Moremory-forigationDataDatueTotheIrfixed-SizenatureAntatureAntatureAndirectMemoryAccess.1)arraysStorelelementsInAcontiguxufulock,ReducingOveringOverheadHeadefromenterSormetormetAdata.2)列表,通常

如何將Python列表轉換為Python陣列?如何將Python列表轉換為Python陣列?May 05, 2025 am 12:10 AM

ToconvertaPythonlisttoanarray,usethearraymodule:1)Importthearraymodule,2)Createalist,3)Usearray(typecode,list)toconvertit,specifyingthetypecodelike'i'forintegers.Thisconversionoptimizesmemoryusageforhomogeneousdata,enhancingperformanceinnumericalcomp

您可以將不同的數據類型存儲在同一Python列表中嗎?舉一個例子。您可以將不同的數據類型存儲在同一Python列表中嗎?舉一個例子。May 05, 2025 am 12:10 AM

Python列表可以存儲不同類型的數據。示例列表包含整數、字符串、浮點數、布爾值、嵌套列表和字典。列表的靈活性在數據處理和原型設計中很有價值,但需謹慎使用以確保代碼的可讀性和可維護性。

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

SublimeText3 Linux新版

SublimeText3 Linux新版

SublimeText3 Linux最新版

Dreamweaver Mac版

Dreamweaver Mac版

視覺化網頁開發工具

WebStorm Mac版

WebStorm Mac版

好用的JavaScript開發工具

PhpStorm Mac 版本

PhpStorm Mac 版本

最新(2018.2.1 )專業的PHP整合開發工具

DVWA

DVWA

Damn Vulnerable Web App (DVWA) 是一個PHP/MySQL的Web應用程序,非常容易受到攻擊。它的主要目標是成為安全專業人員在合法環境中測試自己的技能和工具的輔助工具,幫助Web開發人員更好地理解保護網路應用程式的過程,並幫助教師/學生在課堂環境中教授/學習Web應用程式安全性。 DVWA的目標是透過簡單直接的介面練習一些最常見的Web漏洞,難度各不相同。請注意,該軟體中