pandas ExcelWriter定製格式(定製表頭、渲染顏色等,非ExcelWriter標準的建立模式)
阿新 • • 發佈:2019-04-01
pandas ExcelWriter定製格式(定製表頭、渲染顏色等,非ExcelWriter標準的建立模式)
ExcelWriter這個外掛有個坑,就是已經設定好的格式是無法更改的,因此,由pandas轉成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, # 單元格邊框寬度
'align': 'left', # 水平對齊方式
'valign': 'vcenter', # 垂直對齊方式
'fg_color': '#F4B084', # 單元格背景顏色
'text_wrap': True, # 是否自動換行
})
新增單元格資料:
//row:行, col:列, data:要寫入的資料, 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行選出數值最大的一個‘top1’,並用format1的格式和顏色進行渲染):
worksheet1.conditional_format('A2:A55', {'type': 'top', 'value': 1, 'format': format1})
設定行格式(更改表頭格式):
worksheet1.set_row(0, cell_format=format2)