Python XLWT установить пользовательский цвет фона ячейки - PullRequest
22 голосов
/ 13 октября 2011

Я использую Python 2.7 и модуль xlwt для экспорта в Excel

Я хотел бы установить цвет фона ячейки я знаю, что могу использовать

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

но я бы хотел установить пользовательский цвет как # 8a8eef или есть палитра возможных цветов, потому что светло-синий не работает:)

спасибо

Ответы [ 5 ]

29 голосов
/ 09 января 2014

В настоящее время существует способ (изначально предложенный здесь ) для определения и использования собственного цвета с использованием 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')

Также посмотрите фактический запрос на получение , который сделал это возможным.

12 голосов
/ 05 марта 2013

Если вы не используете 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
5 голосов
/ 13 октября 2011

Сведения о предварительно определенных цветах см. xlwt.Style._colour_map_text в Style.py .

Чтобы использовать пользовательские цвета, вам, вероятно, придется переопределить палитру, потому что цвета используются не непосредственно в ячейках, а как индекс для цвета в палитре. Я не знаю, как расширить палитру. К сожалению.

2 голосов
/ 07 июля 2017

Я рекомендую использовать XlsxWriter, также имеет потрясающие функции.http://xlsxwriter.readthedocs.io/

2 голосов
/ 03 апреля 2015

Альтернативное решение:

Если вы можете избежать использования цветов, определенных в xlwt, перейдите на информационный сайт о цвете, например http://www.colorhexa.com/90ee90 исоответствует одному из следующих цветов Python Excel: http://bit.ly/1NMH67F

...