【问题标题】:python xlwt set custom background colour of a cellpython xlwt设置单元格的自定义背景颜色
【发布时间】:2017-07-07 05:38:50
【问题描述】:

我正在使用 python 2.7 和 xlwt 模块进行 excel 导出

我想设置单元格的背景颜色 我知道我可以使用

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

但我想设置自定义颜色。喜欢#8a8eef 或者是否有可能的颜色调色板,因为浅蓝色不起作用:)

谢谢

【问题讨论】:

    标签: python excel format xlwt


    【解决方案1】:

    现在,有一种方法(最初建议 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。你有什么理由选择它吗?如果我想添加更多,我应该使用0x220x23等吗?
    • @Nick source code 建议0x21 可以是8 <= colour_index <= 63 范围内的任何数字
    • 请注意,您可以通过覆盖现有的调色板颜色来省略add_palette_colour。示例:book.set_colour_RGB(0x16, 245, 245, 245); style = xlwt.easyxf('pattern: pattern solid, fore_colour gray25')
    • 注意:虽然add_palette_colour() 接受颜色名称中的大写字母,但尝试在easyxf() 中使用它们会失败。如果需要,请确保您申请 .lower()
    【解决方案2】:

    如果您不使用 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
    

    【讨论】:

      【解决方案3】:

      对于预定义的颜色,请参阅 Style.py 中的 xlwt.Style._colour_map_text

      要使用自定义颜色,您可能必须重新定义调色板,因为颜色不是直接在单元格中使用,而是作为调色板中颜色的索引。我不知道如何扩展调色板。对不起。

      【讨论】:

      • 有没有办法给单元格添加自定义RGB颜色?
      • @IshikawaYoshi 是的,请检查我的答案。
      【解决方案4】:

      替代解决方案:

      如果您可以不使用 xlwt 中定义的颜色,请访问颜色信息网站,如 http://www.colorhexa.com/90ee90,并使用以下 Python Excel 颜色之一进行匹配:http://bit.ly/1NMH67F

      【讨论】:

        【解决方案5】:

        我推荐使用 XlsxWriter,它也有很棒的功能。 http://xlsxwriter.readthedocs.io/

        【讨论】:

        • XlsxWriter 有更直观的 API b/c 它使用键值对来设置格式
        • xlwt 用于旧的 xls 格式,而 xlsxwriter 用于新格式,因此它们不可互换。
        猜你喜欢
        • 1970-01-01
        • 2021-10-19
        • 2010-11-21
        • 1970-01-01
        • 2017-02-08
        • 2016-12-18
        • 1970-01-01
        • 2020-12-14
        • 2015-06-02
        相关资源
        最近更新 更多