我正在使用Python 2.7和xlwt模块进行Excel导出。
我想设置单元格的背景颜色, 我知道可以使用
style1 = xlwt.easyxf('pattern: pattern solid, fore_colour red;')
但是我想设置自定义颜色,类似于 #8a8eef,或者是否有可能的颜色调色板可用,因为浅蓝色不起作用 :)
谢谢
现今,有一种方法(最初在这里提出)可以使用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')
同时查看实际的拉取请求,这是使之发生的。
easyxf()
,而是逐步构建XFStyle
对象,这里有另一种使用用户友好的颜色名称的方法: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
预定义的颜色请参见Style.py中的xlwt.Style._colour_map_text
。
如果要使用自定义颜色,您可能需要重新定义调色板,因为颜色不直接用于单元格,而是用作调色板中颜色的索引。我不知道如何扩展调色板。抱歉。
备选方案:
如果您可以使用xlwt中定义的颜色,可以前往像http://www.colorhexa.com/90ee90这样的颜色信息网站,并从以下Python Excel颜色之一进行匹配:http://bit.ly/1NMH67F
0x21
。你选择它有什么原因吗?如果我想添加更多,我应该使用0x22
、0x23
等吗? - Nick0x21
可以是范围在8 <= colour_index <= 63
的任何数字。 - moriestaadd_palette_colour
。例如:book.set_colour_RGB(0x16, 245, 245, 245); style = xlwt.easyxf('pattern: pattern solid, fore_colour gray25')
- Blaiseadd_palette_color()
接受颜色名称中的大写字母,但在easyxf()
中使用它们会失败。 如果需要,请确保使用.lower()
。 - Arnaud P