ExcelWriter這個插件有個坑,就是已經設置好的格式是沒法更改(緣由詳見這裏)的。並且有以下問題:一、沒法分別給一個單元格寫入值和樣式. 對於單個單元格, 必須在寫入值的同時爲單元格寫入樣式. 關於這個, 能夠用 set_column 和 set_row 解決, 它們的實質是設置該列/行的默認樣式。二、沒法同時給一個單元格套用兩種樣式。html
所以,由pandas轉成excel的時候,必須將格式清除,尤爲是表頭的格式,代碼以下:python
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之間添加代碼:spa
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當中添加自定義格式集合:excel
format1 = workbook1.add_format({'bg_color': '#FFC7CE', 'font_color': '#9C0006'}) format2 = workbook1.add_format({'bold': True, 'align': 'left', 'valign': 'top', 'text_wrap': True})
新增格式:code
bold = f.add_format({ 'bold': True, # 字體加粗 'border': 1, # 單元格邊框寬度 'align': 'left', # 水平對齊方式 'valign': 'vcenter', # 垂直對齊方式 'fg_color': '#F4B084', # 單元格背景顏色 'text_wrap': True, # 是否自動換行 })
新增單元格數據:orm
//row:行, col:列, data:要寫入的數據, bold:單元格的樣式 worksheet1.write(row, col, data, bold)
新增圖表(參考連接):htm
設置列寬和顏色:對象
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行選出數值最大的一個‘top1’,並用format1的格式和顏色進行渲染)參考資料:
worksheet1.conditional_format('A2:A55', {'type': 'top', 'value': 1, 'format': format1})
設置行格式(更改表頭格式)更改前須要關閉原有的默認表頭格式,方法能夠有這裏、或者這裏:
worksheet1.set_row(0, cell_format=format2)