




版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
Pandas向本地Excel已存在的工作表追加寫入DataFrame示例:本地存在一個(gè)Excel文件如下,下面我們希望將一個(gè)DataFrame寫入到已存在數(shù)據(jù)的工作表中,并保留原始數(shù)據(jù)。如果我們想直接通過pandas的api實(shí)現(xiàn)幾乎是不可能的,因?yàn)楣俜轿臋nto_excel方法明確說了:Onceaworkbookhasbeensaveditisnotpossiblewritefurtherdatawithoutrewritingthewholeworkbook.但我個(gè)人在研究了pandas的Excel寫出源碼后,有了很簡(jiǎn)單的直接使用pandas向工作表追加數(shù)據(jù)的方法,后續(xù)再演示。測(cè)試數(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版本測(cè)試成功):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è)工作表追加寫對(duì)應(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源,我目前還只能通過阿里云升級(jí)到1.3.5的版本。為了提前嘗鮮,我修改了如下源碼:首先在pa
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 風(fēng)險(xiǎn)管理教育在保險(xiǎn)專業(yè)人才培養(yǎng)中的應(yīng)用考核試卷
- 事故案例分析及教訓(xùn)總結(jié)考核試卷
- 醫(yī)療器械不良事件監(jiān)測(cè)與分析考核試卷
- 政務(wù)數(shù)據(jù)治理與政府透明度提升策略考核試卷
- 內(nèi)燃機(jī)仿真在發(fā)動(dòng)機(jī)輕量化設(shè)計(jì)中的應(yīng)用考核試卷
- 儀器考核試題及答案
- 輔警考試題目及答案
- 酒店試題及答案
- 種禽技術(shù)員考試試題及答案
- 魔法穿越測(cè)試題及答案
- 欣賞《嘎達(dá)梅林》-課件
- GB/T 4074.8-2009繞組線試驗(yàn)方法第8部分:測(cè)定漆包繞組線溫度指數(shù)的試驗(yàn)方法快速法
- GB/T 28575-2020YE3系列(IP55)三相異步電動(dòng)機(jī)技術(shù)條件(機(jī)座號(hào)63~355)
- 國(guó)際公法學(xué) 馬工程課件 4 第四章
- 青海省西寧市《職業(yè)能力測(cè)試》事業(yè)單位國(guó)考真題
- 溝通中的提問技巧課件
- 2023年浙江黃龍?bào)w育發(fā)展有限公司招聘筆試模擬試題及答案解析
- 外科學(xué)骨折概論課件
- 阿片類藥物鎮(zhèn)痛機(jī)制課件
- 產(chǎn)品成本核算流程圖
- 母線槽安裝檢驗(yàn)批質(zhì)量驗(yàn)收記錄
評(píng)論
0/150
提交評(píng)論