Excelize 释出 2.6.0 版本,功能强大的 Excel 档案基础库

Excelize 释出 2.6.0 版本,功能强大的 Excel 档案基础库

Excelize 是 Go 语言编写的用於操作 Office Excel 档案基础库,基於 ECMA-376,ISO/IEC 29500 国际标准。可以使用它来读取、写入由 Microsoft Excel™ 2007 及以上版本创建的电子表格档案。支持 XLAM / XLSM / XLSX / XLTM / XLTX 等多种档案格式,高度兼容带有样式、图片(表)、枢纽分析表、切片器等复杂组件的档案,并提供流式读写 API,用於处理包含大规模数据的活页簿。可应用於各类报表平台、云计算、边缘计算等系统。入选 2020 Gopher China - Go 领域明星开源项目 (GSP)、 2018 开源中国码云 Gitee 最有价值开源项目 GVP,目前已成为 Go 语言最受欢迎的 Excel 档案基础库。

2022年4月11日,社区正式释出了 2.6.0 版本,该版本包含了多项新增功能、错误修复和兼容性提升优化。下面是有关该版本更新内容的摘要,完整的更改列表可查看 changelog
此版本中最显着的变化包括:

兼容性提示

  • 重命名导出常量 NameSpaceDublinCoreMetadataIntiativeNameSpaceDublinCoreMetadataInitiative 以修复拼写错误
  • 重命名导出变数 ErrUnsupportEncryptMechanismErrUnsupportedEncryptMechanism
  • 重命名导出变数 ErrDataValidationFormulaLenthErrDataValidationFormulaLength
  • 重命名导出变数 ErrDefinedNameduplicateErrDefinedNameDuplicate
  • 移除了导出变数 XMLHeaderByte
  • 移除了设置数据数据验证列表函数 SetSqrefDropList 的第二个形参 isCurrentSheet 和异常返回值
  • 移除了列迭代器中的导出字段 TotalRows

新增功能

  • ProtectSheet 新增支持通过指定的算法保护工作表,支持的算法包括: XOR、MD4、MD5、SHA1、SHA256、SHA384 和 SHA512
  • UnprotectSheet 支持通过指定第二个可选参数在移除工作表保护时验证密码
  • 新增 71 项公式函数: AVERAGEIFS, BETADIST, BETA.DIST, BETAINV, BETA.INV, BINOMDIST, BINOM.DIST, BINOM.DIST.RANGE, BINOM.INV, CHIINV, CHITEST, CHISQ.DIST, CHISQ.DIST.RT, CHISQ.INV, CHISQ.INV.RT, CHISQ.TEST, CONFIDENCE.T, CORREL, COVAR, COVARIANCE.P, CRITBINOM, ERROR.TYPE, EXPON.DIST, EXPONDIST, F.DIST, F.DIST.RT, FDIST, F.INV, F.INV.RT, FINV, FORMULATEXT, F.TEST, FTEST, GAMMA.DIST, GAMMADIST, GAMMA.INV, GAMMAINV, GAMMALN.PRECISE, GAUSS, HOUR, HYPGEOM.DIST, HYPGEOMDIST, INDIRECT, LOGINV, LOGNORM.DIST, LOGNORMDIST, LOGNORM.INV, MODE, MODE.MULT, MODE.SNGL, NEGBINOM.DIST, NEGBINOMDIST, PHI, SECOND, SERIESSUM, SUMIFS, SUMPRODUCT, SUMX2MY2, SUMX2PY2, SUMXMY2, T.DIST, T.DIST.2T, T.DIST.RT, TDIST, TIMEVALUE, T.INV, T.INV.2T, TINV, T.TEST, TTEST, TYPE
  • 保存或另存为活页簿时增加对文件扩展名进行检查
  • 支持设置活页簿视图模式和显示/隐藏标尺
  • 引入依赖库 NFP (number format parser) 以增加对自定义时间、日期和文本类型数字格式的支持,可对包含 19 种语言(南非荷兰语、孟加拉语、汉语、英语、法语、德语、奥地利语、爱尔兰语、意大利语、俄语、西班牙语、泰语、藏语、土耳其语、威尔士语、沃洛夫语、科萨语、彝语和祖鲁语)本地月份名称和 12 小时制格式的数字格式表达式进行解析,相关 issues #660, #764, #1093, #1112 和 #1133
  • 新增 API: SetWorkbookPrOptionsGetWorkbookPrOptions 支持设置和获取活页簿中的 FilterPrivacyCodeName 属性,以解除部分情况下向活页簿中嵌入 VBA 工程时的限制,相关 issue #1148
  • 公式计算引擎支持中缀运算符後包含无参数公式函数的计算
  • 支持以文本形式读取布尔型存储格的值
  • 通过 AddChart 函数添加圆环图时,支持指定圆环图内径大小,解决 issue #1172
  • 新增导出 4 项错误信息 ErrPasswordLengthInvalid, ErrUnsupportedHashAlgorithm, ErrUnsupportedNumberFormat, ErrWorkbookExt,以便开发者可根据不同的错误类型进行采取相应处理

兼容性提升

  • 提升与 LibreOffice 电子表格应用程序的兼容性,修复在 LibreOffice 中打开的工作表名包含空格时,自动过滤器失效的问题,解决 issue #1122
  • 提升对活页簿中替代内容的支持,保留活页簿、工作表以及 drawingML 中的替代内容
  • 提升与页面设置中打印质量 DPI 设置属性的兼容性

问题修复

  • 修复另存为活页簿时,页面布局属性丢失的问题,解决 issue #1117
  • 修复部分情况下,对工作表进行修改後合并存储格区域未更新的问题
  • 修复样式解析异常导致的粗体和部分其他字体样式丢失问题,解决 issue #1119
  • 修复部分情况下将文档保存为 XLAM / XLSM / XLTM / XLTX 格式後文档损坏的问题
  • 存储格样式支持继承列/栏样式,以修复对工作表进行修改後合并存储格区域存储格样式不正确的问题,解决 issue #1129
  • 修复部分情况下获取存储格样式 ID 错误的问题
  • 修复编号为 42 的内建数字格式定义错误的问题
  • 修复部分情况下数字精度解析错误的问题
  • SetCellDefault 支持设置非数字类型存储格的值,解决 issue #1139
  • 修复部分情况下另存为活页簿时,显示或隐藏工作表标签属性丢失的问题,解决 issue #1160
  • 修复部分情况下嵌套公式计算错误的问题,解决 issue #1164
  • 修复部分情况下公式计算结果精度不准确以及在 x86 和 arm64 架构 CPU 下公式计算结果精度不一致的问题
  • 修复部分情况下使用科学记数法表示的数值解析失败的问题
  • 修复图表轴最大值最小值为 0 时不起作用的问题

性能优化

  • 提高使用列迭代器进行流式读取的性能,当读取包含大规模数据的电子表格文档时,内存开销相较於上一版本降低最高约 50%,内存垃圾回收次数降低约 80%

其他

  • Go Modules 依赖模块更新
  • 单元测试与文档更新
  • 包含简体中文、英语、法语、俄语、日语、韩语、阿拉伯语、德语和西班牙语的多国语言文档网站更新

<<:  【C#】Number Random

>>:  网路功能虚拟化(NFV)、软件定义网路(SDN)、软件定义边界 (SDP) 和零信任(Zero Trust)

Day 05 关键字比对,让你花钱不浪费

我们想像今天有个消费者想要搜寻「五倍红宝石」,却只用了「红宝石」这个关键字,他可能会搜出一堆「红宝石...

Vuex 的使用偏好

这是我个人的使用偏好,而且是以抽象资料型别的使用方式来理解 vuex 的使用方式。也许,我是说也许...

33岁转职者的前端笔记-DAY 8 前端网页基础小知识

今天来点比较轻松的文章吧 学任何技能前,了解基础知识也是必要的 其实也能帮助後续学习的速度呢 前端网...

Day 01: 【序】– 架构与设计、代码、工程师

「你因为两个原因来读这本书:首先,你是位程序设计师。再者,你想成为一位更好的程序设计师」 取自: ...

TypeScript 能手养成之旅 Day 4 基础型别 & 扩充型别

前言 前面介绍完型别注解和型别推论,今天要和大家来谈 TypeScript 有哪些类型的型别,在这些...