Excelize 是 Go 语言编写的用于操作 Office Excel 文档基础库,基于 ECMA-376,ISO/IEC 29500 国际标准。可以使用它来读取、写入由 Excel、WPS、OpenOffice 等办公软件创建的电子表格文档。支持 XLAM / XLSM / XLSX / XLTM / XLTX 等多种文档格式,高度兼容带有样式、图片 (表)、透视表、切片器等复杂组件的文档,并提供流式读写支持,用于处理包含大规模数据的工作簿。可应用于各类报表平台、云计算、边缘计算等系统。自 2016 年开源以来已成为云原生应用尤其是 Go 语言开发者在处理电子表格办公文档时的热门选择,正在被广泛应用于大型互联网公司、中小企业客户和初创公司。荣获 2025 上海开源创新菁英奖、入选 2023 开源创新榜优秀开源项目、荣获 2022 年中国开源创新大赛一等奖、2020 Gopher China - Go 领域明星开源项目 (GSP)、2018 年开源中国码云最有价值开源项目 GVP (Gitee Most Valuable Project)。
2025年10月14日,社区正式发布了 2.10.0 版本,该版本包含了多项新增功能、错误修复和兼容性提升优化。下面是有关该版本更新内容的摘要,此版本中最显著的变化包括:
此版本中最显著的变化包括:
golang.org/x/crypto
ErrTransparency
ChartDashType
、CustomProperty
和 ZipWriter
ChartMarker
数据类型中新增 Border
字段ChartLegend
数据类型中新增 Font
字段ChartSeries
数据类型中新增 Legend
字段Fill
数据类型中新增 Transparency
字段ChartLine
数据类型中新增 Dash
和 Fill
字段Options
数据类型中新增 TmpDir
字段,支持指定用于创建临时文件的临时目录,相关 issue 2024Font
数据类型中新增 Charset
字段,支持指定字体编码GetCustomProps
和 SetCustomProps
,支持获取和设置工作簿的自定义属性,相关 issue 2146SetZipWriter
,支持设置自定义 ZIP 写入器,相关 issue 2199GetMergeCells
中新增可选参数 withoutValues
,支持获取合并单元格时忽略读区合并单元格的值DeleteDataValidation
支持删除扩展列表中的数据验证,并支持通过引用序列数组或空格分隔的引用字符串,对多个单元格范围进行删除,相关 issue 2133AddChart
支持设置图表的虚线样式和数据点边框类型AddChart
支持设置图表图例的字体,相关 issue 2169AddChart
和 AddChartSheet
支持创建 4 种箱体和蜡烛图类型股票图表:最高价 - 最低价 - 收盘价、开盘价 - 最高价 - 最低价 - 收盘价、成交量 - 最高价 - 最低价 - 收盘价、成交量 - 开盘价 - 最高价 - 最低价 - 收盘价图表CalcCellValue
支持计算 BAHTTEXT 公式函数GetSheetDimension
采用流式解析,相较于上个正式版本速度最高提升约 95%,内存分配降低约 96%感谢 Excelize 的所有贡献者,以下是为此版本提交代码的贡献者列表:
《Excelize 权威指南》不仅介绍了 Excelize 库的基本使用方法,还深入探索了高级特性和应用场景。全书共分五个篇章:入门指南、基础库设计概览、深入 Excelize、高性能流式读写技术以及实践应用。通过这本书,你将学会如何利用 Go 语言和 Excelize 库,实现 Excel 文件的自动化处理、复杂数据分析以及报表生成等任务。
你将不再受限于 Excel 的传统操作方式,而是能够通过编程的方式,解锁 Excel 新境界,创造出更加智能、高效的数据处理解决方案。
欢迎加入 Excelize 开源技术交流群