web-dev-qa-db-ja.com

python xlwtセルのカスタム背景色を設定

私はpython 2.7とExcelエクスポート用のxlwtモジュールを使用しています

使用できるセルの背景色を設定したい

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

カスタムカラーの色を設定したいのですが。 #8a8eefのように、または水色が機能しないため、可能な色のパレットがあります:)

ありがとうございました

23
Yebach

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
12
darklow

現在、add_palette_colour()およびset_colour_RGB()を使用してカスタムカラーを定義および使用する方法(当初提案された here )があります。

次に例を示します。

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 も参照してください。

30
alecxe

事前定義された色については、 Style.pyxlwt.Style._colour_map_textを参照してください。

カスタム色を使用するには、色をセルで直接使用するのではなく、パレット内の色のインデックスとして使用するため、おそらくパレットを再定義する必要があります。パレットを拡張する方法がわかりません。ごめんなさい。

5
Michał Šrajer

XlsxWriterの使用をお勧めします。すばらしい機能も備えています。 http://xlsxwriter.readthedocs.io/

2
Angie Alejo

代替ソリューション:

Xlwtで定義された色でうまくいく場合は、 http://www.colorhexa.com/90ee9 のような色情報サイトにアクセスし、次のいずれかと一致させますPython Excelの色: http://bit.ly/1NMH67F

2
Sandeep