python xlwt设置单元格的自定义背景颜色
我使用python 2.7和xlwt模块进行excel导出
我想设置一个单元格的背景颜色,我知道我可以使用
style1 = xlwt.easyxf('pattern: pattern solid, fore_colour red;')
但我想设置自定义颜色不适用。 像#8a8eef或者是否有可能的颜色调色板,因为淡蓝色不工作:)
谢谢
如果您不使用easyxf()
,而是逐步构buildXFStyle
对象,则可以使用用户友好的颜色名称:
import xlwt style = xlwt.XFStyle() pattern = xlwt.Pattern() pattern.pattern = xlwt.Pattern.SOLID_PATTERN pattern.pattern_fore_colour = xlwt.Style.colour_map['dark_purple'] style.pattern = pattern
现在,有一种方法(最初在这里提出)使用add_palette_colour()
和set_colour_RGB()
来定义和使用自定义颜色。
这是一个例子:
import xlwt book = xlwt.Workbook() # add new colour to palette and set RGB colour value xlwt.add_palette_colour("custom_colour", 0x21) book.set_colour_RGB(0x21, 251, 228, 228) # now you can use the colour in styles sheet1 = book.add_sheet('Sheet 1') style = xlwt.easyxf('pattern: pattern solid, fore_colour custom_colour') sheet1.write(0, 0, 'Some text', style) book.save('test.xls')
另请参阅实现此function的实际请求 。
有关预定义的颜色,请参阅xlwt.Style._colour_map_text
中的xlwt.Style._colour_map_text 。
要使用自定义颜色,您必须重新定义调色板,因为颜色不是直接在单元格中使用,而是作为调色板中的颜色索引。 我不知道如何扩展调色板。 抱歉。
替代scheme:
如果您可以使用xlwt中定义的颜色,请转到颜色信息网站(如http://www.colorhexa.com/90ee90),并使用以下Python Excel颜色之一进行匹配: http : //bit.ly/1NMH67F
我推荐使用XlsxWriter,也有很棒的function。 http://xlsxwriter.readthedocs.io/