中文字幕理论片,69视频免费在线观看,亚洲成人app,国产1级毛片,刘涛最大尺度戏视频,欧美亚洲美女视频,2021韩国美女仙女屋vip视频

打開(kāi)APP
userphoto
未登錄

開(kāi)通VIP,暢享免費(fèi)電子書(shū)等14項(xiàng)超值服

開(kāi)通VIP
Pandas寫(xiě)入Excel函數(shù)

Pandas作為Python數(shù)據(jù)分析的一個(gè)常用包,經(jīng)常會(huì)與Excel交互。
最近經(jīng)常使用pandas的to_excel函數(shù),發(fā)現(xiàn)坑還不少。經(jīng)常報(bào)錯(cuò),覆蓋寫(xiě)入,讓人煩躁。甚至Run一遍后,excel文件里只剩一個(gè)sheet或者文件根本打不開(kāi)。
經(jīng)過(guò)兩周使用,總算有點(diǎn)門(mén)道了。

下面是我對(duì)to_excel函數(shù)一些技術(shù)總結(jié)。

一、單個(gè)sheet寫(xiě)入:

import pandas as pd df1 = pd.DataFrame({'One': [1, 2, 3]}) df1.to_excel('excel1.xlsx', sheet_name='Sheet1', index=False) # index false為不寫(xiě)入索引

excel1.xlsx 不存在的話,則會(huì)新建文件,再寫(xiě)入 Sheet1。 
excel1.xlsx 已存在的話,則會(huì)新建,寫(xiě)入,再覆蓋。
所以無(wú)論 excel1.xlsx 是否存在,上述代碼的結(jié)果是一樣的。它的作用就是新建 excel1.xlsx(文件已存在則覆蓋),寫(xiě)入 Sheet1。excel1.xlsx 中最后只有一個(gè)表 Sheet1。
 

當(dāng)Pandas要寫(xiě)入多個(gè)sheet時(shí),to_excel第一個(gè)參數(shù)excel_writer要選擇ExcelWriter對(duì)象,不能是文件的路徑。否則,就會(huì)覆蓋寫(xiě)入。
ExcelWriter可以通過(guò)上下文管理器來(lái)執(zhí)行,省去save(),優(yōu)雅。


二、多個(gè)sheet寫(xiě)入到同一個(gè)Excel

import pandas as pd

df1 = pd.DataFrame({'One': [1, 2, 3]})
df2 = pd.DataFrame({'Two': [4, 5, 6]})

with pd.ExcelWriter('excel1.xlsx') as writer:
    df1.to_excel(writer, sheet_name='Sheet1', index=False)
    df2.to_excel(writer, sheet_name='Sheet2', index=False)

Once a workbook has been saved it is not possible write further data without rewriting the whole workbook.
to_excel的Doc中有上面一句話,所以,ExcelWriter可以看作一個(gè)容器,一次性提交所有to_excel語(yǔ)句后再保存,從而避免覆蓋寫(xiě)入。


三、新增sheet,不覆蓋已存在的sheet

沿用上面的代碼,excel1.xlsx 已存在,增加一個(gè)新的表 Sheet3。這里,ExcelWriter的參數(shù)mode='a',模式改為新增,非寫(xiě)入('w')。
注意:這里模式的新增指的是sheet,不是對(duì)sheet的內(nèi)容進(jìn)行新增。

import pandas as pd df3 = pd.DataFrame({'Three': [7, 8, 9]}) with pd.ExcelWriter('excel1.xlsx', mode='a') as writer: df3.to_excel(writer, sheet_name='Sheet3', index=False)

同樣,新增兩個(gè)sheet

import pandas as pd

df4 = pd.DataFrame({'Four': [11, 22, 33]})
df5 = pd.DataFrame({'Five': [55, 66, 77]})

with pd.ExcelWriter('excel1.xlsx', mode='a') as writer:
    df4.to_excel(writer, sheet_name='Sheet4', index=False)
    df5.to_excel(writer, sheet_name='Sheet5', index=False)

四、修改sheet中的內(nèi)容,不覆蓋已存在的sheet

沿用上面的代碼,修改Sheet4、Sheet5。

import pandas as pd from openpyxl import load_workbook df41 = pd.DataFrame({'Four': [44, 55, 66]}) df51 = pd.DataFrame({'Five': [77, 88, 99]}) with pd.ExcelWriter('excel1.xlsx') as writer: book = load_workbook('excel1.xlsx') writer.book = book # 讀取excel writer.sheets = dict((ws.title, ws) for ws in book.worksheets) # 復(fù)制excel的所有表 df41.to_excel(writer, sheet_name='Sheet4', index=False) df51.to_excel(writer, sheet_name='Sheet5', index=False)

  其實(shí),這是一個(gè)折中的方案,先用openpyxl 讀取到了excel1,載入excel1的內(nèi)容到ExcelWriter中,再對(duì)Sheet4、Sheet5進(jìn)行覆蓋寫(xiě)入。
 

  Sheet5中追加數(shù)據(jù)。 to_excel的參數(shù)startrow、startcol為寫(xiě)入的起始行列。header為是否寫(xiě)入列名。

import pandas as pd
from openpyxl import load_workbook

df6 = pd.DataFrame({'Six': [11, 22, 33]})
df7 = pd.DataFrame({'SEVEN': ['AA', 'BB', 'CC']})

with pd.ExcelWriter('excel1.xlsx') as writer:
    book = load_workbook('excel1.xlsx')
    writer.book = book
    writer.sheets = dict((ws.title, ws) for ws in book.worksheets)
    df6.to_excel(writer, sheet_name='Sheet5', index=False, startrow=0, startcol=3)
    df7.to_excel(writer, sheet_name='Sheet5', index=False, header=False, startrow=4, startcol=0)

利用startrow、startcol兩個(gè)參數(shù),我們不僅可以追加數(shù)據(jù),還可以用覆蓋寫(xiě)入的方式去修改sheet的部分內(nèi)容。比如將'ARE YOU OK?'寫(xiě)入Sheet5的Six列

import pandas as pd from openpyxl import load_workbook df8 = pd.DataFrame({'EIGHT': ['ARE', 'YOU', 'OK?']}) with pd.ExcelWriter('excel1.xlsx') as writer: book = load_workbook('excel1.xlsx') writer.book = book writer.sheets = dict((ws.title, ws) for ws in book.worksheets) df8.to_excel(writer, sheet_name='Sheet5', index=False, header=False, startrow=2, startcol=3)



總結(jié):
to_excel是將pandas數(shù)據(jù)保存到Excel文件中的一個(gè)函數(shù),從字面上看,它的功能是格式轉(zhuǎn)化存儲(chǔ)。它操作的基本單位是一個(gè)個(gè)的sheet以及sheet組成的excel文件。
雖然,通過(guò)先讀取,再寫(xiě)入的方法可以實(shí)現(xiàn)單個(gè)sheet的內(nèi)容追加、修改功能,但這是一個(gè)“笨方法”,不優(yōu)雅。
當(dāng)有這類(lèi)對(duì)單個(gè)sheet的內(nèi)容追加、修改功能需求時(shí),可以直接使用openpyxl、xlwings等第三方包。to_excel的底層引擎也是這些包。

參考
ExcelWrite Doc
to_excel Doc
Openpyxl Doc with Pandas

本站僅提供存儲(chǔ)服務(wù),所有內(nèi)容均由用戶發(fā)布,如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請(qǐng)點(diǎn)擊舉報(bào)。
打開(kāi)APP,閱讀全文并永久保存 查看更多類(lèi)似文章
猜你喜歡
類(lèi)似文章
Pandas向本地Excel已存在的工作表追加寫(xiě)入DataFrame
pandas 生成 Excel 時(shí)的 sheet 問(wèn)題
利用 pandas 批量合并 Excel
pandas.DataFrame.to
用Python 創(chuàng)建 Excel 高級(jí)工作表
使用Python將多個(gè)工作表保存到一個(gè)Excel文件中
更多類(lèi)似文章 >>
生活服務(wù)
熱點(diǎn)新聞
分享 收藏 導(dǎo)長(zhǎng)圖 關(guān)注 下載文章
綁定賬號(hào)成功
后續(xù)可登錄賬號(hào)暢享VIP特權(quán)!
如果VIP功能使用有故障,
可點(diǎn)擊這里聯(lián)系客服!

聯(lián)系客服