我使用python 2.7和xlwt模塊Excel導出蟒蛇xlwt集中小區自定義背景色
我想設置的小區 我知道的backgroung顏色我可以使用
style1 = xlwt.easyxf('pattern: pattern solid, fore_colour red;')
但我想設置自定義顏色。像#8a8eef 還是有可能的顏色的調色板,因爲淺藍色不工作:)
謝謝
我使用python 2.7和xlwt模塊Excel導出蟒蛇xlwt集中小區自定義背景色
我想設置的小區 我知道的backgroung顏色我可以使用
style1 = xlwt.easyxf('pattern: pattern solid, fore_colour red;')
但我想設置自定義顏色。像#8a8eef 還是有可能的顏色的調色板,因爲淺藍色不工作:)
謝謝
如果你不使用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
。
要使用自定義顏色,您必須重新定義調色板,因爲顏色不是直接在單元格中使用,而是作爲調色板中顏色的索引。我不知道如何擴展調色板。抱歉。
如今,有一種方法(最初提出here)使用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')
也看到實際pull request是讓這一切發生。
在你的例子中,你使用了'0x21'。你有什麼理由選擇它嗎?如果我想添加更多,我應該使用'0x22','0x23'等等嗎? – Nick
@Nick [源代碼](https://github.com/python-excel/xlwt/blob/917a8ad8db35d6e8abb306a2fda2ace648a6ab89/xlwt/Style.py#L374)表明0x21可以是範圍內的任何數字8 <= colour_index <= 63' – Acute
請注意,您可以通過覆蓋現有的調色板顏色來省略'add_palette_colour'。例如:'book.set_colour_RGB(0x16,245,245,245); style = xlwt.easyxf('pattern:pattern solid,fore_colour gray25')' – Blaise
替代解決方案:
如果你能逃脫在xlwt定義的顏色,去一個顏色信息的網站,如http://www.colorhexa.com/90ee90和匹配從下面的Python Excel的顏色之一:http://bit.ly/1NMH67F
我推薦使用XlsxWriter,也有很棒的功能。 http://xlsxwriter.readthedocs.io/
XlsxWriter具有更直觀的API b/c,它使用鍵值對來設置格式 – Wes
有什麼方法可以將自定義RGB顏色添加到單元格嗎? –
@IshikawaYoshi是的,請檢查我的答案。 – alecxe