python xlwt 设置单元格自定义背景颜色

24 投票
5 回答
56433 浏览
提问于 2025-04-17 04:12

我正在使用 Python 2.7 和 xlwt 模块来导出 Excel 文件。

我想给一个单元格设置背景颜色,我知道可以用

style1 = xlwt.easyxf('pattern: pattern solid, fore_colour red;')

但是我想设置一个自定义颜色,比如 #8a8eef,或者有没有可能的颜色调色板,因为浅蓝色不太好用 :)

谢谢你!

5 个回答

6

要查看预定义的颜色,可以去看一下 xlwt.Style._colour_map_text,这个内容在 Style.py 文件里。

如果你想使用自定义颜色,可能需要重新定义调色板,因为在单元格中使用的颜色并不是直接写颜色,而是用调色板中的索引来表示。我不知道怎么扩展调色板,抱歉。

35

现在,有一种方法(最初是在这里提出的)可以使用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')

还可以查看实际的拉取请求,这个请求让这项功能得以实现。

13

如果你没有使用 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

撰写回答