web-dev-qa-db-fra.com

python xlwt définit la couleur d'arrière-plan personnalisée d'une cellule

J'utilise python 2.7 et module xlwt pour l'exportation Excel

Je voudrais définir la couleur d'arrière-plan d'une cellule que je sais pouvoir utiliser

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

mais je voudrais définir une couleur personnalisée. comme # 8a8eef ou y a-t-il une palette de couleurs possibles, car le bleu clair ne fonctionne pas :)

merci

23
Yebach

Si vous n'utilisez pas easyxf() et que vous construisez à la place l'objet XFStyle étape par étape, voici une autre façon d'utiliser des noms de couleurs conviviaux:

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

De nos jours, il existe un moyen (initialement proposé ici ) de définir et d'utiliser une couleur personnalisée en utilisant add_palette_colour() et set_colour_RGB().

Voici un exemple:

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')

Voir également le pull request qui a rendu cela possible.

30
alecxe

Pour les couleurs prédéfinies, voir xlwt.Style._colour_map_text in Style.py .

Pour utiliser des couleurs personnalisées, vous devrez probablement redéfinir la palette, car les couleurs ne sont pas utilisées directement dans les cellules mais comme un index à colorier dans une palette. Je ne sais pas comment étendre la palette. Désolé.

5
Michał Šrajer

Je recommande d'utiliser XlsxWriter, a aussi des fonctionnalités impressionnantes. http://xlsxwriter.readthedocs.io/

2
Angie Alejo

Solution alternative:

Si vous pouvez vous en tirer avec les couleurs définies dans xlwt, accédez à un site d'informations sur les couleurs comme http://www.colorhexa.com/90ee9 et faites correspondre l'une des options suivantes Python Couleurs Excel: http://bit.ly/1NMH67F

2
Sandeep