使用 Python 在 Excel 中创建组合图
在实际业务报表中,我们经常会遇到这样一种场景: 例如: 如果将它们放在同一个纵轴上展示,要么销量几乎贴地不可见,要么销售额被压缩失真。这时,组合图(Combo Chart)就是更专业的选择。 组合图允许: 本文将完整演示如何使用 Python 创建组合图表,如“柱状图 + 折线图”,并实现双 Y 轴展示。 示例基于 Free Spire.XLS for Python,可通过 pip 安装: 首先创建工作簿,并准备示例数据结构。 注意事项: 关键点说明: 说明: 销售额通常数值较大,适合使用柱状图进行视觉强调。 关键逻辑: 通过双轴机制,可以避免数值比例冲突。 图表位置通过单元格坐标控制,这种方式比像素定位更稳定。 生成的 Excel 文件将包含: 无需手动修改即可直接使用。 生成结果预览: 组合图并不是简单的“两个图叠加”,它是一种表达结构关系的工具。 在自动化报表系统中,如果仅生成单一图表,往往难以满足管理层对趋势与规模同时分析的需求。而通过 Python 自动创建组合图,我们可以: 借助 Python,我们无需打开 Excel 界面,即可构建具备企业级视觉表达能力的分析报表。 当自动化系统开始承担经营分析任务时,组合图能力将成为报表系统的重要组成部分。掌握这一能力,意味着你不仅在生成数据文件,而是在输出真正具备决策价值的业务图形。 更多 Excel 文件处理技巧,请前往 Spire.XLS for Python 官方教程查看。
两个指标存在关联,但量级差异较大。pip install spire.xls.free1. 初始化工作簿与销售数据
from spire.xls import *
# 创建工作簿
workbook = Workbook()
# 获取工作表
sheet = workbook.Worksheets.get_Item(0)
sheet.Name = "销售图表演示"
# 设置表头
sheet.Range["A1"].Text = "月份"
sheet.Range["B1"].Text = "销售额"
sheet.Range["C1"].Text = "销量"
# 示例数据
data = [
("1月", 12000, 300),
("2月", 18500, 420),
("3月", 15000, 360),
("4月", 21000, 500),
("5月", 19500, 460),
]
row = 2
for item in data:
sheet.Range[f"A{row}"].Text = item[0]
sheet.Range[f"B{row}"].NumberValue = item[1]
sheet.Range[f"C{row}"].NumberValue = item[2]
row += 1NumberValue2. 创建组合图对象
# 添加图表
chart = sheet.Charts.Add()
# 设置数据范围
chart.DataRange = sheet.AllocatedRange
chart.SeriesDataFromRange = False
# 设置组合图类型
chart.ChartType = ExcelChartType.CombinationChartCombinationChart 表示组合图模式SeriesDataFromRange = False 表示按列拆分数据系列3. 设置柱状图系列(销售额)
sales_series = chart.Series.get_Item(0)
sales_series.SerieType = ExcelChartType.ColumnStacked
sales_series.Name = "销售额($)"
sales_series.UsePrimaryAxis = TrueSerieType 控制该数据系列的图表类型UsePrimaryAxis = True 表示使用主 Y 轴(左侧)4. 设置折线图系列(销量)
amount_series = chart.Series.get_Item(1)
amount_series.SerieType = ExcelChartType.LineMarkers
amount_series.Name = "销量(个)"
amount_series.UsePrimaryAxis = FalseUsePrimaryAxis = False 表示使用副 Y 轴(右侧)5. 设置图表位置与样式
# 设置图表位置
chart.LeftColumn = 4
chart.TopRow = 1
chart.RightColumn = 12
chart.BottomRow = 20
chart.ChartTitle = "2024年销售趋势"
chart.Legend.Position = LegendPositionType.Bottom6. 自动调整列宽并保存文件
sheet.AllocatedRange.AutoFitColumns()
workbook.SaveToFile("CreateCombinationChart.xlsx", FileFormat.Version2016)
workbook.Dispose()
常见组合图注意事项
项目 说明 必须使用 CombinationChart 否则无法混合图表类型 单独设置每个 SerieType 控制不同图形类型 UsePrimaryAxis 控制双轴 True 为左轴,False 为右轴 数据必须为数值类型 使用 NumberValue 总结