Excel插入折线图教程详解
时间:2026-01-26 12:45:53 334浏览 收藏
怎么入门文章编程?需要学习哪些知识点?这是新手们刚接触编程时常见的问题;下面golang学习网就来给大家整理分享一些知识点,希望能够给初学者一些帮助。本篇文章就来介绍《使用openpyxl插入折线图教程》,涉及到,有需要的可以收藏一下
用openpyxl插入折线图需创建LineChart对象,通过Reference指定X轴(如A2:A10)和Y轴(如B1:B10)数据范围,调用set_categories和add_data绑定数据,设置标题、坐标轴名及宽高后,用add_chart插入指定单元格,最后用Excel打开验证图表显示。

用 openpyxl 插入折线图,核心是创建 LineChart 对象、添加数据系列(Reference 和 Series),再把图表加到工作表中。不依赖 Excel 打开状态,纯代码生成,但要注意数据引用范围和坐标轴设置。
准备数据区域
折线图需要明确的 X 轴(类别)和 Y 轴(数值)数据。通常 X 轴放在第一列(如 A2:A10),Y 轴放在相邻列(如 B2:B10)。确保数据连续、无空行空列,且首行为标题(可选,但建议保留以便自动识别)。
- 数据从第 2 行开始,避免把表头当数值读取
- 若有多组折线,每组占一列(如 B 列、C 列),X 轴共用同一列
- 用
ws.cell(row=..., column=...).value = ...或ws.append(...)写入数据更稳妥
创建 LineChart 并绑定数据
先导入 LineChart 和 Reference,然后指定数据源。关键在 Reference 的范围要准确——X 轴用 min_col/max_col 控制列,Y 轴用 min_row/max_row 控制行。
- X 轴引用:例如
Reference(ws, min_col=1, min_row=2, max_row=10)(A2:A10) - Y 轴引用:例如
Reference(ws, min_col=2, min_row=1, max_row=10)(B1:B10),含标题行才设min_row=1 - 用
chart.set_categories(x_data)设置横坐标,chart.add_data(y_data, titles_from_data=True)加入折线(True 表示首行作图例名)
调整图表样式与位置
openpyxl 默认图表较小且无标题。可通过属性微调,再用 ws.add_chart(..., "D2") 指定左上角单元格锚点。
- 加标题:
chart.title = "销售趋势" - 设坐标轴名称:
chart.x_axis.title = "月份",chart.y_axis.title = "销售额(万元)" - 改大小(单位为 EMU):
chart.width = 480,chart.height = 288 - 插入位置写成字符串,如
"E5",不是元组或数字索引
保存文件并验证
调用 wb.save("report.xlsx") 后,必须用 Excel(而非 WPS 或网页版)打开才能正常显示图表——openpyxl 生成的是标准 OOXML 图表,部分兼容性较弱的工具可能只显示空白框。
- 如果图表不显示,先检查是否漏掉
add_data()或set_categories() - 数据为字符串或空值会导致折线消失,可用
print([cell.value for cell in ws['B2:B10']])快速排查 - 不支持动态公式引用(如
=Sheet1!A1*2),所有数据需为实际数值或文本
基本上就这些。不复杂但容易忽略引用范围和保存后的查看环境。
本篇关于《Excel插入折线图教程详解》的介绍就到此结束啦,但是学无止境,想要了解学习更多关于文章的相关知识,请关注golang学习网公众号!
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
227 收藏
-
339 收藏
-
281 收藏
-
104 收藏
-
268 收藏
-
481 收藏
-
377 收藏
-
327 收藏
-
346 收藏
-
113 收藏
-
220 收藏
-
211 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 485次学习