版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡介
Pandas向本地Excel已存在的工作表追加寫入DataFrame示例:本地存在一個(gè)Excel文件如下,下面我們希望將一個(gè)DataFrame寫入到已存在數(shù)據(jù)的工作表中,并保留原始數(shù)據(jù)。如果我們想直接通過pandas的api實(shí)現(xiàn)幾乎是不可能的,因?yàn)楣俜轿臋nto_excel方法明確說了:Onceaworkbookhasbeensaveditisnotpossiblewritefurtherdatawithoutrewritingthewholeworkbook.但我個(gè)人在研究了pandas的Excel寫出源碼后,有了很簡單的直接使用pandas向工作表追加數(shù)據(jù)的方法,后續(xù)再演示。測試數(shù)據(jù):importpandasaspddf=pd.DataFrame([[1,2,3],[4,5,6],[7,8,9]],columns=['A','B','C'])openpyxl向工作表追加Pandas數(shù)據(jù)下面我們首先看看,直接用openpyxl如何實(shí)現(xiàn),完整代碼如下:fromopenpyxlimportload_workbookbook=load_workbook("first.xlsx")sheet=book.activeaddress="G8"start_row,start_col=sheet[address].row-1,sheet[address].column-1forj,vinenumerate(df.columns,1):sheet.cell(start_row+1,start_col+j).value=vfori,rowinenumerate(df.values,2):forj,vinenumerate(row,1):sheet.cell(start_row+i,start_col+j).value=vbook.save("test.xlsx")結(jié)果如下,成功向G8單元格寫入數(shù)據(jù):xlwings向工作表追加Pandas數(shù)據(jù)如果我們windows系統(tǒng)本地有安裝office或目前版本的wps,就可以通過xlwings向工作表追加Pandas數(shù)據(jù),完整代碼如下:importxlwingsasxwapp=xw.App(add_book=False)wb=app.books.open("first.xlsx")sht=wb.sheets.activesht.range('G8').options(index=False).value=dfwb.save("test.xlsx")app.quit()實(shí)現(xiàn)了與上述openpyxl代碼一樣的效果,save方法與openpyxl也一樣,不傳參數(shù)則覆蓋原始文件。options參數(shù)可以設(shè)置DataFrame的寫出形式,與to_excel的參數(shù)幾乎一致。Pandas直接向工作表追加數(shù)據(jù)最終完整代碼如下(在pandas1.2.4版本測試成功):writer=pd.ExcelWriter("first.xlsx",engine='openpyxl',mode='a')writer.sheets.update({sht.title:shtforshtinwriter.book.worksheets})df.to_excel(writer,sheet_name=writer.book.active.title,index=False,startrow=7,startcol=6)writer.close()上述代碼會(huì)向Excel表中的激活的工作表追加參數(shù),sheet_name參數(shù)也可以指定向哪個(gè)工作表追加寫對應(yīng)的字符串。在1.4.0以上版本使用如下代碼即可:writer=pd.ExcelWriter("first.xlsx",engine='openpyxl',mode='a',if_sheet_exists="overlay")df.to_excel(writer,sheet_name=writer.book.active.title,index=False,startrow=7,startcol=6)writer.close()默認(rèn)情況下pandas無法向Excel工作表追加數(shù)據(jù)的根本原因在于沒有任何讀取原本工作表的動(dòng)作,根據(jù)源碼可以看到永遠(yuǎn)都會(huì)新建工作表(Pandas1.2.x以下版本的情況):這樣我們只需要讓sheets獲取到已存在的工作表信息即可。但是我在1.3.5版本中運(yùn)行以上代碼卻報(bào)出如下錯(cuò)誤:這是因?yàn)閺?.3.0版本開始,pd.ExcelWriter增加了if_sheet_exists選項(xiàng):上述我實(shí)現(xiàn)的功能在1.4.0以上版本已經(jīng)實(shí)現(xiàn),使用如下代碼即可:writer=pd.ExcelWriter("first.xlsx",engine='openpyxl',mode='a',if_sheet_exists="overlay")df.to_excel(writer,sheet_name=writer.book.active.title,index=False,startrow=7,startcol=6)writer.close()但是目前阿里云還沒有同步1.4.X版本的pip源,我目前還只能通過阿里云升級到1.3.5的版本。為了提前嘗鮮,我修改了如下源碼:首先在pa
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲(chǔ)空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 贛南醫(yī)學(xué)院《安裝工程施工技術(shù)》2023-2024學(xué)年第一學(xué)期期末試卷
- 贛南師范大學(xué)科技學(xué)院《邏輯推理證明》2023-2024學(xué)年第一學(xué)期期末試卷
- 電氣培訓(xùn)課件題目
- 贛東學(xué)院《控制系統(tǒng)建模與仿真B》2023-2024學(xué)年第一學(xué)期期末試卷
- 甘孜職業(yè)學(xué)院《公司戰(zhàn)略與風(fēng)險(xiǎn)管理》2023-2024學(xué)年第一學(xué)期期末試卷
- 甘肅政法大學(xué)《水污染控制工程(一)設(shè)計(jì)》2023-2024學(xué)年第一學(xué)期期末試卷
- 鐵塔安全培訓(xùn)課件
- 七年級道德與法治上冊第三單元師長情誼第六課師生之間第二框師生交往教案新人教版
- 三年級數(shù)學(xué)上冊教材梳理數(shù)與代數(shù)新人教版
- 三年級科學(xué)上冊第三單元人與動(dòng)物5動(dòng)物世界教案首師大版1
- 獸用疫苗管理制度
- 2023瑞幸員工合同協(xié)議書
- 大氣數(shù)據(jù)測試儀校準(zhǔn)規(guī)范
- 硬筆書法田字格標(biāo)準(zhǔn)尺寸
- 升降柱 施工方案
- 中建辦公商業(yè)樓有限空間作業(yè)專項(xiàng)施工方案
- 堤防工程施工規(guī)范
- 小細(xì)胞肺癌治療進(jìn)展及預(yù)后
- 成品出貨檢驗(yàn)報(bào)告模板
- 湖北省武漢市江岸區(qū)2023-2024學(xué)年四上數(shù)學(xué)期末檢測模擬試題含答案
- 藍(lán)色手繪風(fēng)美術(shù)學(xué)碩士畢業(yè)論文答辯ppt模板
評論
0/150
提交評論