如何使用 XlsxWriter 绘制条形图并为同一系列中的每个条形图填充不同的颜色

How can I use XlsxWriter to plot a barchart and fill in different colors for each of the bar in the same series

例如,我有 3 个数据元素(例如 49、23、40),分别为 Jan、Feb 和 Mar,它们都属于同一个系列 1。当我将它们绘制在条形图中时,它们可以只能在 XlsxWriter 中用相同的颜色填充。我该怎么做才能用不同的颜色填充它们?谢谢!

通常在 XlsxWriter(和 Excel)中,您可以使用 line and/or fill 属性设置条形图的颜色。

要为每个条设置颜色,您需要为系列中的每个点设置颜色。例如:

import xlsxwriter

workbook = xlsxwriter.Workbook('chart.xlsx')
worksheet = workbook.add_worksheet()

worksheet.write_column('A1', ['Jan', 'Feb', 'Mar'])
worksheet.write_column('B1', [49,    23,     40])

chart = workbook.add_chart({'type': 'bar'})

chart.add_series({
    'categories': '=Sheet1!$A:$A',
    'values':     '=Sheet1!$B:$B',
    'points': [
        {'fill': {'color': 'red'}},
        {'fill': {'color': 'green'}},
        {'fill': {'color': 'blue'}},
    ],
})

worksheet.insert_chart('B5', chart)
workbook.close()

输出:

请参阅 chart series point options and Working with Colors 上的 XlsxWriter 文档。