<p align="center"><img src="https://xuri.me/excelize/images/excelize.svg" width="440" alt="github.com/360EntSecGroup-Skylar/excelize" /></p>
[Excelize](https://github.com/xuri/excelize) 是 Go 语言编写的用于操作 Office Excel 文档基础库,基于 ECMA-376,ISO/IEC 29500 国际标准。可以使用它来读取、写入由 Microsoft Excel™ 2007 及以上版本创建的电子表格文档。支持 XLSX / XLSM / XLTM 等多种文档格式,高度兼容带有样式、图片(表)、透视表、切片器等复杂组件的文档,并提供流式读写 API,用于处理包含大规模数据的工作簿。可应用于各类报表平台、云计算、边缘计算等系统。入选 2020 Gopher China - Go 领域明星开源项目 (GSP)、 2018 开源中国码云 [Gitee 最有价值开源项目 GVP](https://gitee.com/xurime/excelize),目前已成为 Go 语言最受欢迎的 Excel 文档基础库。
## 开源代码
**GitHub:** [github.com/xuri/excelize](https://github.com/xuri/excelize)
**Gitee:** [gitee.com/xurime/excelize](https://gitee.com/xurime/excelize)
**中文文档:** [xuri.me/excelize/zh-hans](https://xuri.me/excelize/zh-hans/)
2021年1月4日,社区正式发布了 2.3.2 版本,该版本包含了多项新增功能、错误修复和兼容性提升优化。下面是有关该版本更新内容的摘要,完整的更改列表可查看 [changelog](https://github.com/xuri/excelize/compare/v2.3.1...v2.3.2)。
## Release Notes
此版本中最显著的变化包括:
### 新增功能
* 数据透视表 API [`AddPivotTable`](https://pkg.go.dev/github.com/360EntSecGroup-Skylar/excelize/v2#File.AddPivotTable) 支持缺省列与多重数据源,相关 issue [#710](https://github.com/xuri/excelize/pull/710)
* 使用 [`GetCellValue`](https://pkg.go.dev/github.com/360EntSecGroup-Skylar/excelize/v2#File.GetCellValue) 获取单元格的值支持自定义日期与时间数字格式,相关 issue [#703](https://github.com/xuri/excelize/pull/703)
* 计算单元格的值 API [`CalcCellValue`](https://pkg.go.dev/github.com/360EntSecGroup-Skylar/excelize/v2#File.CalcCellValue) 新增公式函数支持 `AND`、`CLEAN`、`TRIM`、`LOWER`、`PROPER`、`UPPER` 和 `OR`,相关 issue [#701](https://github.com/xuri/excelize/issues/701) 和 [#747](https://github.com/xuri/excelize/pull/747)
* 数据验证新增支持浮点型小数区间验证规则,相关 issue [#739](https://github.com/xuri/excelize/issues/739)
* 创建图表 API [`AddChart`](https://pkg.go.dev/github.com/360EntSecGroup-Skylar/excelize/v2#File.AddChart) 新增支持设置数据系列线型宽度和线端类型,相关 issue [#549](https://github.com/xuri/excelize/issues/549) 和 [#654](https://github.com/xuri/excelize/issues/654)
* 创建图表 API [`AddChart`](https://pkg.go.dev/github.com/360EntSecGroup-Skylar/excelize/v2#File.AddChart) 支持指定是否关闭不与图表重叠的图例
### 兼容性提升
* 提升包含 6 个以上数据系列的折线图与 Kingsoft WPS™ 应用程序的兼容性,相关 issue [#627](https://github.com/xuri/excelize/issues/627)
* 避免部分情况下工作簿内部样式数据产生的冗余
* 动态解析工作簿核心数据部件
* 支持工作表中多行复用相同行标签的工作簿,相关 issue [#732](https://github.com/xuri/excelize/issues/732)
### 问题修复
* 修复公式词法分析器解析特定非法公式时潜在的 panic 问题,相关 issue [#711](https://github.com/xuri/excelize/issues/711)
* 修复使用相同名称进行重命名工作表时导致工作表丢失的问题,相关 issue [#713](https://github.com/xuri/excelize/issues/713)
* 修复部分情况下 [`NewSheet`](https://pkg.go.dev/github.com/360EntSecGroup-Skylar/excelize/v2#File.NewSheet) 返回工作表索引错误的问题,相关 issue [#714](https://github.com/xuri/excelize/issues/714)
* 修复特定情况下使用非内建数字格式 ID 应用单元格数字格式时产生的 panic 问题,相关 issue [#715](https://github.com/xuri/excelize/issues/715) 和 [#741](https://github.com/xuri/excelize/pull/741)
* 修正公式计算引擎数据精度,相关 issue [#727](https://github.com/xuri/excelize/issues/727)
* 修复部分情况下复制行数据失效的问题,相关 issue [#729](https://github.com/xuri/excelize/pull/729)
* 修复部分情况下删除工作表后默认活动工作表错误的问题,相关 issue [#735](https://github.com/xuri/excelize/issues/735)
* 修复当使用 [`AddPicture`](https://pkg.go.dev/github.com/360EntSecGroup-Skylar/excelize/v2#File.AddPicture) 向带有多个合并单元格的工作表中插入图片时,指定自适应尺寸失效的问题,相关 issue [#748](https://github.com/xuri/excelize/issues/748)
* 修复部分情况下复制行时,合并单元格处理异常的问题,相关 issue [#752](https://github.com/xuri/excelize/issues/752)
### 性能优化
* 流式写入数据时的内存使用降低约 60%,相关 issue [#659](https://github.com/xuri/excelize/pull/659)
* 优化内部方法 `worksheetWriter` 运行时对内存分配的影响,相关 issue [#722](https://github.com/xuri/excelize/pull/722)
* 提高 [`AddPicture`](https://pkg.go.dev/github.com/360EntSecGroup-Skylar/excelize/v2#File.AddPicture) 添加图片 API 的性能,相关 issue [#706](https://github.com/xuri/excelize/issues/706)
### 其他
* 单元测试与文档更新
* 新增 3 种文档语言:阿拉伯语、德语和西班牙语
* 欢迎加入技术交流群
DingTalk Group ID: [`30047129`](https://qr.dingtalk.com/action/joingroup?code=v1,k1,2oHMIIOyvPcGezVdHJjsHwdZzzYNI6xs3Oww8uhlvCk=&_dt_no_comment=1&origin=11)
QQ Group ID: [`207895940`](https://jq.qq.com/?_wv=1027&k=5imdV9h)
WeChat ID: `hixuri` (请备注: Excelize)
<img width="700" src="https://xuri.me/excelize/zh-hans/images/group@2x.png" alt="Excelize 技术交流群">
有疑问加站长微信联系(非本文作者)