python xlwt set custom background colour of a cell

痞子三分冷 提交于 2019-11-28 07:25:15
darklow

If you are not using easyxf() and instead are building XFStyle object step by step, here is another way of using user friendly color names:

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

Nowadays, there is a way (originally proposed here) to define and use custom colour using add_palette_colour() and set_colour_RGB().

Here's an example:

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')

Also see the actual pull request that made this happen.

Michał Šrajer

For predefined colors see xlwt.Style._colour_map_text in Style.py.

To use custom colors you will have to probably redefine palette, because colors are not used directly in cells but as a index to color in a palette. I don't know how to extend palette. Sorry.

Alternative solution:

If you can get away with the colors defined in xlwt, go to a color information site like http://www.colorhexa.com/90ee90 and match from one of the following Python Excel colors: http://bit.ly/1NMH67F

I recommend to use XlsxWriter, has awesome features too. http://xlsxwriter.readthedocs.io/

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!