- A+
所屬分類:百科知識
pandas ExcelWriter定制格式(定制表頭、渲染顏色等,非ExcelWriter標準的創建模式)
ExcelWriter這個插件有個坑,就是已經設置好的格式是無法更改的,因此,由pandas轉成excel的時候,必須將格式清除,尤其是表頭的格式,代碼如下:
|
1
2
|
import pandas.io.formats.excelpandas.io.formats.excel.header_style = None |
標準的保存pandas表到excel的形式為:
|
1
2
3
4
|
writer = pd.ExcelWriter(output_prefix + cv_excel_file_name)df.to_excel(writer, 'Sheet1')? # 這里假設df是一個pandas的dataframewriter.save()writer.close() |
如果要定制輸出的excel格式,那么得在to_excel和save之間添加代碼:
|
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 Worksheetworkbook1 = writer.bookworksheets = writer.sheetsworksheet1 = worksheets['Sheet1']writer.save()writer.close() |
有了相應的workbook和worksheet對象,我們就可以參照官方教程來定制我們的輸出excel格式了!
我們在操作worksheet中的各自前,需要往workbook當中添加自定義格式集合:
|
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}) |
增:
新增格式:
|
1
2
3
4
5
6
7
8
|
bold = f.add_format({????????'bold':? True,? # 字體加粗????????'border': 1,? # 單元格邊框寬度????????'align': 'left',? # 水平對齊方式????????'valign': 'vcenter',? # 垂直對齊方式????????'fg_color': '#F4B084',? # 單元格背景顏色????????'text_wrap': True,? # 是否自動換行????}) |
新增單元格數據:
|
1
2
|
//row:行, col:列, data:要寫入的數據, bold:單元格的樣式worksheet1.write(row, col, data, bold) |
刪:
改(這里主要介紹改的方法):
設置列寬和顏色:
|
1
2
|
yellow = workbook1.add_format({'fg_color': '#FFEE99'})worksheet1.set_column("E:E", 16, cell_format=yellow) |
設置列寬(B列到AE列所有的列寬都為16):
|
1
|
worksheet1.set_column("B:AE", 16) |
設置條件格式(令A列2到55行選出數值最大的一個‘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操作的文章就介紹到這了
贊
0
賞

