Python xlwt устанавливает пользовательский цвет фона ячейки
Я использую python 2.7 и модуль xlwt для экспорта excel
Я хотел бы установить backgroung цвет ячейки
Я знаю, что могу использовать
style1 = xlwt.easyxf('pattern: pattern solid, fore_colour red;')
но я хотел бы установить собственный цвет smth. вроде # 8a8eef
или есть палитра возможных цветов, потому что светло-голубой не работает:)
Благодарю вас
Ответы
Ответ 1
Если вы не используете 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
Ответ 2
В настоящее время существует способ (изначально предлагаемый здесь) для определения и использования пользовательского цвета с использованием 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')
Также см. фактический запрос на перенос, который сделал это.
Ответ 3
Для предопределенных цветов см. xlwt.Style._colour_map_text
в Style.py.
Чтобы использовать пользовательские цвета, вам нужно будет переопределить палитру, потому что цвета не используются непосредственно в ячейках, а как индекс для цвета в палитре. Я не знаю, как расширить палитру. К сожалению.
Ответ 4
Альтернативное решение:
Если вы можете уйти с цветами, определенными в xlwt, перейдите на сайт с информацией о цвете, например http://www.colorhexa.com/90ee90 и сопоставьтесь с одним из следующие цвета Python Excel: http://bit.ly/1NMH67F
Ответ 5
Я рекомендую использовать XlsxWriter, также есть удивительные функции.
http://xlsxwriter.readthedocs.io/