使用Pandas的ExcelWriter操作excel的方法
pandas ExcelWriter定制格式(定制表頭、渲染顏色等,非ExcelWriter標準的創(chuàng)建模式)
ExcelWriter這個插件有個坑,就是已經(jīng)設置好的格式是無法更改的,因此,由pandas轉(zhuǎn)成excel的時候,必須將格式清除,尤其是表頭的格式,代碼如下:
import pandas.io.formats.excel pandas.io.formats.excel.header_style = None
標準的保存pandas表到excel的形式為:
writer = pd.ExcelWriter(output_prefix + cv_excel_file_name) df.to_excel(writer, 'Sheet1') # 這里假設df是一個pandas的dataframe writer.save() writer.close()
如果要定制輸出的excel格式,那么得在to_excel和save之間添加代碼:
writer = pd.ExcelWriter(output_prefix + cv_excel_file_name) df.to_excel(writer, 'Sheet1') # 這里假設df是一個pandas的dataframe # =================== add self define code here ======================= # from xlsxwriter.workbook import Workbook # from xlsxwriter.worksheet import Worksheet workbook1 = writer.book worksheets = writer.sheets worksheet1 = worksheets['Sheet1'] writer.save() writer.close()
有了相應的workbook和worksheet對象,我們就可以參照官方教程來定制我們的輸出excel格式了!
我們在操作worksheet中的各自前,需要往workbook當中添加自定義格式集合:
format1 = workbook1.add_format({'bg_color': '#FFC7CE', 'font_color': '#9C0006'}) format2 = workbook1.add_format({'bold': True, 'align': 'left', 'valign': 'top', 'text_wrap': True})
增:
新增格式:
bold = f.add_format({ 'bold': True, # 字體加粗 'border': 1, # 單元格邊框?qū)挾? 'align': 'left', # 水平對齊方式 'valign': 'vcenter', # 垂直對齊方式 'fg_color': '#F4B084', # 單元格背景顏色 'text_wrap': True, # 是否自動換行 })
新增單元格數(shù)據(jù):
//row:行, col:列, data:要寫入的數(shù)據(jù), bold:單元格的樣式 worksheet1.write(row, col, data, bold)
刪:
改(這里主要介紹改的方法):
設置列寬和顏色:
yellow = workbook1.add_format({'fg_color': '#FFEE99'}) worksheet1.set_column("E:E", 16, cell_format=yellow)
設置列寬(B列到AE列所有的列寬都為16):
worksheet1.set_column("B:AE", 16)
設置條件格式(令A列2到55行選出數(shù)值最大的一個‘top1’,并用format1的格式和顏色進行渲染):
worksheet1.conditional_format('A2:A55', {'type': 'top', 'value': 1, 'format': format1})
設置行格式(更改表頭格式):
worksheet1.set_row(0, cell_format=format2)
到此這篇關于如何使用Pandas的ExcelWriter進行excel操作的文章就介紹到這了,更多相關Pandas 操作excel內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
Python中Windows和macOS文件路徑格式不一致的解決方法
在 Python 中,Windows 和 macOS 的文件路徑字符串格式不一致主要體現(xiàn)在路徑分隔符上,這種差異可能導致跨平臺代碼在處理文件路徑時出錯,下面我們看看如何解決吧2025-03-03Keras 實現(xiàn)加載預訓練模型并凍結網(wǎng)絡的層
這篇文章主要介紹了Keras 實現(xiàn)加載預訓練模型并凍結網(wǎng)絡的層,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-06-06python使用Windows的wmic命令監(jiān)控文件運行狀況,如有異常發(fā)送郵件報警
這篇文章主要介紹了python使用Windows的wmic命令監(jiān)控文件運行狀況,如有異常發(fā)送郵件報警的示例,幫助大家更好的理解和使用python,感興趣的朋友可以了解下2021-01-01