pandas ExcelWriter定制格式(定制表頭、渲染顏色等,非ExcelWriter標準的創(chuàng)建模式)
ExcelWriter這個插件有個坑,就是已經(jīng)設置好的格式是無法更改的,因此,由pandas轉成excel的時候,必須將格式清除,尤其是表頭的格式,代碼如下:文章源自四五設計網(wǎng)-http://www.133122.cn/39759.html
1 2 | import pandas.io.formats.excel pandas.io.formats.excel.header_style = None |
標準的保存pandas表到excel的形式為:文章源自四五設計網(wǎng)-http://www.133122.cn/39759.html
1 2 3 4 | 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之間添加代碼:文章源自四五設計網(wǎng)-http://www.133122.cn/39759.html
1 2 3 4 5 6 7 8 9 10 | 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格式了!文章源自四五設計網(wǎng)-http://www.133122.cn/39759.html
我們在操作worksheet中的各自前,需要往workbook當中添加自定義格式集合:文章源自四五設計網(wǎng)-http://www.133122.cn/39759.html
1 2 | format1 = workbook1.add_format({ 'bg_color' : '#FFC7CE' , 'font_color' : '#9C0006' }) format2 = workbook1.add_format({ 'bold' :? True , 'align' : 'left' , 'valign' : 'top' , 'text_wrap' : True }) |
文章源自四五設計網(wǎng)-http://www.133122.cn/39759.html
增:
新增格式:文章源自四五設計網(wǎng)-http://www.133122.cn/39759.html
1 2 3 4 5 6 7 8 | bold = f.add_format({ ???????? 'border' : 1 ,? # 單元格邊框寬度 ???????? 'align' : 'left' ,? # 水平對齊方式 ???????? 'valign' : 'vcenter' ,? # 垂直對齊方式 ???????? 'fg_color' : '#F4B084' ,? # 單元格背景顏色 ???????? 'text_wrap' : True ,? # 是否自動換行 ???? }) |
新增單元格數(shù)據(jù):文章源自四五設計網(wǎng)-http://www.133122.cn/39759.html
1 2 | / / row:行, col:列, data:要寫入的數(shù)據(jù), bold:單元格的樣式 worksheet1.write(row, col, data, bold) |
刪:
改(這里主要介紹改的方法):
設置列寬和顏色:文章源自四五設計網(wǎng)-http://www.133122.cn/39759.html
1 2 | yellow = workbook1.add_format({ 'fg_color' : '#FFEE99' }) worksheet1.set_column( "E:E" , 16 , cell_format = yellow) |
設置列寬(B列到ae列所有的列寬都為16):文章源自四五設計網(wǎng)-http://www.133122.cn/39759.html
1 | worksheet1.set_column( "B:AE" , 16 ) |
設置條件格式(令A列2到55行選出數(shù)值最大的一個‘top1’,并用format1的格式和顏色進行渲染):
1 | worksheet1.conditional_format( 'A2:A55' , { 'type' : 'top' , 'value' : 1 , 'format' : format1}) |
設置行格式(更改表頭格式):
1 | worksheet1.set_row( 0 , cell_format = format2) |
到此這篇關于如何使用Pandas的ExcelWriter進行excel操作的文章就介紹到這了


評論