首页 > 其他分享 >Excelize 开源基础库 2.9.0 版本正式发布

Excelize 开源基础库 2.9.0 版本正式发布

时间:2024-10-16 13:25:45浏览次数:1  
标签:修复 Excelize 单元格 开源 问题 2.9 解决 issue 函数

Excelize 开源基础库 2.9.0 版本正式发布

Excelize 是 Go 语言编写的用于操作 Office Excel 文档基础库,基于 ECMA-376,ISO/IEC 29500 国际标准。可以使用它来读取、写入由 Excel、WPS、OpenOffice 等办公软件创建的电子表格文档。支持 XLAM / XLSM / XLSX / XLTM / XLTX 等多种文档格式,高度兼容带有样式、图片(表)、透视表、切片器等复杂组件的文档,并提供流式读写支持,用于处理包含大规模数据的工作簿。可应用于各类报表平台、云计算、边缘计算等系统。自 2016 年开源以来已成为云原生应用尤其是 Go 语言开发者在处理电子表格办公文档时的热门选择,正在被广泛应用于大型互联网公司、中小企业客户和初创公司。入选 2023 开源创新榜优秀开源项目、荣获 2022 年中国开源创新大赛一等奖、2020 Gopher China - Go 领域明星开源项目 (GSP)、2018 年开源中国码云最有价值开源项目 GVP (Gitee Most Valuable Project)。

开源代码

GitHub: github.com/xuri/excelize

中文文档: xuri.me/excelize/zh-hans

2024 年 10 月 15 日,社区正式发布了 2.9.0 版本,该版本包含了多项新增功能、错误修复和兼容性提升优化。下面是有关该版本更新内容的摘要,此版本中最显著的变化包括:

兼容性提示

  • 将数据类型 ConditionalFormatOptions 中的字段 Format 修改为指针类型,解决 issue #1867

新增功能

  • 新增函数 DeleteSlicerGetSlicers 支持删除和获取切片器,相关 issue #810
  • 新增函数 MoveSheet 支持移动工作表在工作簿中的位置,相关 issue #1076
  • 数据类型 GraphicOptions 中添加了新的字段 AutoFitIgnoreAspect 支持添加图片时以忽略比例的方式填充单元格
  • 数据类型 ChartAxis 中添加了新的字段 TickLabelPosition 以支持设置图表坐标轴标签的位置
  • 数据类型 PivotTableField 中添加了新的字段 ShowAllInsertBlankRowNumFmt
  • 数据类型 PivotTableOptions 中添加了新的字段 ClassicLayoutFieldPrintTitlesItemPrintTitles
  • 新增 2 项枚举类型 ChartTickLabelPositionTypePictureInsertType
  • 新增举类型值 ChartLineUnset
  • 新增 4 项新增扩展资源标识常量 ExtURIDataFieldExtURIPivotFieldExtURIPivotFilterExtURIPivotHierarchy
  • 新增导出错误变量 ErrPivotTableClassicLayout
  • 函数 MergeCell 合并单元格时将清除除合并区域左上角单元格之外其他单元格的值
  • 函数 AddDataValidationDeleteDataValidationGetCellStyle 支持并发安全调用,相关 issues #1825 和 #1903
  • 获取数据验证函數 GetDataValidations 支持获取存储于扩展列表中的数据验证规则,相关 issue #1835
  • 设置工作表名称函数 SetSheetName 支持大小写敏感,相关 issue #1856
  • 函数 GetPictureCellsGetPictures 支持获取通过 IMAGE 公式添加的图片和内部以绝对路径形式存储的图片
  • GraphicOptions 数据类型中新增了 AutoFitIgnoreAspect 选项,支持以忽略原始纵横比例的方式将图片尺寸填充单元格
  • 设置超链接函数 SetCellHyperLink 支持指定 linkType 为 None 以删除单元格超链接,相关 issue #1940
  • 添加图表函数 AddChart 支持创建带有多个相同图表类型的组合图表,相关 issue #1940
  • 添加图表函数 AddChart 支持设置散点图线型
  • 使用 AddPivotTable 函数创建数据透视表时,若数据源引用的单元格范围内首行单元格的值为空,将返回错误,相关 issue #1945
  • 读取单元格的值时,支持应用带有语言/地区标签和 ID 的数字格式表达式
  • 读取单元格的值时,支持为时间和时间间隔应用动态数字格式,相关 issue #2004
  • 新增公式函数:DOLLAR

兼容性提升

  • 提升了读取带有对齐格式的数字格式单元格的兼容性,解决 issue #1847
  • 提升了对内部带有命名空间前缀的工作表部件的兼容性,解决 issue #1886
  • 提升了对内部带有绝对路径多媒体部件的兼容性,解决 issue #1888

问题修复

  • 修复 v2.8.1 中引入的问题,自动过滤器在 LibreOffice 中失效的问题,解决 issue #1830
  • 修复 v2.8.1 中引入的问题,删除行列时支持调整带有多重单元格引用的数据验证,解决 issue #1831
  • 修复 v2.8.1 中引入的问题,修复了复制行时,如果工作表中带有多重单元格引用的条件格式或数据验证,将返回错误的问题
  • 修复 v2.8.1 中引入的问题,修复了多次保存时单元格的值设置有误的问题,解决 issue #1906
  • 修复 v2.8.1 中引入的问题,修复了迷你图预期外地出现在多张工作表中的问题,解决 issue #1910
  • 公式计算函数 CalcCellValue 支持计算带有矩阵参数的公式函数 ISNUMBER、OR 和 FIND,解决 issue #1819
  • 修复部分情况下公式计算函数 CalcCellValue 计算结果数值舍入精度有误的问题,解决 issue #1851
  • 修复计算函数 CalcCellValue 对带有 XIRR 和 XNPV 的公式计算结果有误问题,解决 issue #1989
  • 修复部分情况下 RemoveCol 函数返回错误的问题,解决 issue #1829
  • 修复部分公式计算函数 DATE 的计算结果数据类型有误的问题,解决 issue #1833
  • 修复读取内部工作表部件中缺少 r 属性的工作簿时,出现 panic 的问题
  • 修复部分情况下,插入行或列后,单元格公式中的括号出现丢失的问题,解决 issue #1861
  • 修复部分情况下,数据验证规则中的部分字符被不正确地转义问题
  • 修复流式写入单元格的值时,部分字符无法正确显示的问题,解决 issue #1865
  • 保存工作簿时将对内部部件排序,以获得一致的文件哈希值和正确的互联网媒体类型,解决 issue #1889
  • 修复添加图表函数 AddChart 在组合图表中设置坐标轴格式失效的问题,解决 issue #1921
  • 修复添加图表函数 AddChart 设置图表主坐标轴标题位置有误的问题
  • 修复添加图表函数 AddChart 设置垂直次坐标轴标题无法被正常显示的问题,解决 issue #1926
  • 修复添加图表函数 AddChart 设置折线图线型无效的问题
  • 修复部分情况下获取数据透视表函数 GetPivotTables 返回数据透视表的数据源范围有误的问题,解决 issue #1937
  • 修复获取样式函数 GetStyle 在读取不包含 sysClr 属性的工作簿时出现 panic 的问题,解决 issue #1963
  • 修复获取单元格富文本函数 GetCellRichText 在读取不包含共享字符串表索引单元格时返回错误的问题,解决 issue #1999
  • 修复使用 SetSheetVisible 函数读取不含视图属性的工作表时出现 panic 的问题,解决 issue #1969
  • 修复部分情况下读取带有数字格式单元格的值时,百分比符号丢失的问题,解决 issue #1942
  • 修复带有负数值的散点图水平坐标轴不现实的问题
  • 修复因删除行列而调整图片、图表、形状等绘图对象位置后,与形状相关联的宏丢失的问题,解决 issue #1957
  • 修复部分情况下删除列后,条件格式丢失的问题,解决 issue #1968
  • 修复部分情况下读取数值单元格的值精度有误的问题,解决 issue #1979
  • 支持设置单元格的值为 IEEE 754 “非数字”值或无穷大,解决 issue #119 和 #1955

性能优化

  • 修复 v2.8.0 中引入的性能下降和内存占用增加问题
  • 降低了按行获取全部单元格的值函数 GetRows 的内存占用,相关 issue #1874
  • 优化了索引转列名函数 ColumnNumberToName 的性能,最多降低内存占用 50%,耗时最多减少 50%

其他

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

致谢

感谢 Excelize 的所有贡献者,以下是为此版本提交代码的贡献者列表:

  • mirgong (helloWorld)
  • YueChenXu-Kimi (岳晨旭)
  • JackMin1314 (陈王)
  • paolobarbolini (Paolo Barbolini)
  • iEvan-lhr (Evan lu)
  • yetyear (yeahyear)
  • ha5ky (hu5ky)
  • lizhichao (vic)
  • realzuojianxiang (realzuojianxiang)
  • msackman (Matthew Sackman)
  • yyle88 (yangyile-yyle88)
  • yunkeweb (yunkeweb)
  • iraj720 (Nima)
  • jianxinhou
  • barlevd
  • 18409615759 (nna)
  • qijinkui (xiaokui)
  • user1121114685 (联盟少侠)
  • wangsongyan
  • vsemichev (Vovka Morkovka)
  • zhayt (Aybek)
  • ShowerBandV (ShowerBandV)
  • imink (Patrick Wang)
  • samkeke (wxy)
  • pjh591029530
  • zhangyimingdatiancai
  • wanghaochen2024
  • centurion-hub
  • peng (Zhang Zhipeng)
  • slashdotdash (Ben Smith)
  • ArcholSevier
  • liuwangchao
  • Zncl2222 (Jian Yu, Chen)

《Excelize权威指南》新书发布

Excelize 开源基础库 2.8.1 版本发布, 2024 年首个更新

《Excelize权威指南》不仅介绍了 Excelize 库的基本使用方法,还深入探索了高级特性和应用场景。全书共分五个篇章:入门指南、基础库设计概览、深入 Excelize、高性能流式读写技术以及实践应用。通过这本书,你将学会如何利用 Go 语言和 Excelize 库,实现 Excel 文件的自动化处理、复杂数据分析以及报表生成等任务。

你将不再受限于 Excel 的传统操作方式,而是能够通过编程的方式,解锁 Excel 新境界,创造出更加智能、高效的数据处理解决方案。

欢迎加入技术交流群

Excelize 技术交流群

标签:修复,Excelize,单元格,开源,问题,2.9,解决,issue,函数
From: https://www.cnblogs.com/xuri/p/18469694/excelize_v2_9_0

相关文章

  • 可人工智能对话的单机游戏《樱园旧梦》游戏、源码、教程,完全免费和开源
    (一)游戏简介特点1:可人工智能对话,女主角自动理解和学习用户(男主角)所教的话语和知识,用户可以提问教过的话语。特点2:很美好的意境,高清全屏的三维虚拟世界。特点3:单机游戏(不联网),绿色游戏(免安装),低配置电脑也可以流畅运行,完全免费、完全开源、完整无缺。play文件夹里DreamStart.ex......
  • OpenAI 开源项目 “swarm” 涉嫌抄袭?智能体 Eagle DevAgent 深度解秘
    近日,OpenAI的新多智能体框架Swarm引发了一场激烈的争议——20岁创始人KyeGomez控诉OpenAI窃取了其初创公司Swarms的知识产权。青年才俊的G创始人声称,OpenAI不仅盗用了其项目的名称,还抄袭了相似的代码结构和方法。这一消息迅速引发了科技社区的广泛关注,这两个......
  • 上海交大开源超逼真声音克隆 TTS;微软探索音生图 AI 模型丨 RTE 开发者日报
       这里是「RTE开发者日报」,每天和大家一起看新闻、聊八卦。 我们的社区编辑团队会整理分享RTE(Real-TimeEngagement)领域内「有话题的新闻」、「有态度的观点」、「有意思的数据」、「有思考的文章」、「有看点的会议」,但内容仅代表编辑的个人观点,欢迎大......
  • 本地部署ComfyUI并添加强大的Flux.1开源文生图模型远程制作AI图片
    文章目录前言1.本地部署ComfyUI2.下载Flux.1模型3.下载CLIP模型4.下载VAE模型5.演示文生图6.公网使用Flux.1大模型6.1创建远程连接公网地址7.固定远程访问公网地址前言本文将详细介绍如何在本地部署ComfyUI并搭建Flux.1文生图神器,......
  • 4、.Net 快速开发框架:DncZeus - 开源项目研究文章
    DncZeus是一个基于ASP.NETCore和Vue.js的前后端分离的通用后台管理系统框架,其愿景是成为一个易于使用且功能丰富的.NETCore通用后台权限管理模板系统基础框架。项目名称"DncZeus"由"Dnc"(.NETCore的缩写)和"Zeus"(古希腊神话中的众神之王)组成,寓意该项目在.N......
  • 一款由AI编写,简洁而实用的开源IP信息查看器
    大家好,今天给大家分享一款用于查询和显示用户当前IP地址的轻量级项目MyIP。MyIP提供了多种功能,包括IP地址查询、网络连通性检查、WebRTC连接检测、DNS泄露检查、网速测试、MTR测试等等。使用MyIP,我们可以轻松地查看自己的公网IP地址,并且可以方便地进行网络诊断或监控。项......
  • 数学建模习题2.9
    importsympyassp定义变量x,y=sp.symbols('xy')定义方程组equation1=sp.Eq(x**2-y-x,3)equation2=sp.Eq(x+3*y,2)解方程组solutions=sp.solve((equation1,equation2),(x,y),dict=True)print("符号解:")forsolinsolutions:print(sol)......
  • 快速部署AI监控系统:思通数科视频卫士的开源解决方案
    AI视频监控卫士的主要应用场景:我们决定开源的原因:灵活性与可定制性:开源产品的代码对用户公开,允许开发者根据特定需求进行自定义和扩展。思通数科AI视频监控卫士作为开源项目,可以灵活适应不同企业或项目的需求。例如,用户可以针对特定的监控场景调整算法,优化人脸识别、行......
  • 开源项目 | DiffIR2VR-Zero:模糊视频8K高清修复技术
     〔更多精彩AI内容,尽在 「魔方AI空间」 公众号,引领AIGC科技时代〕本文作者:猫先生AIGCmagic社区知识库(免费访问)原文地址:开源实操|DiffIR2VR-Zero:模糊视频8K高清修复技术简介DiffIR2VR-Zero:一种创新的零样本视频恢复技术,该技术利用预训练的图像恢复模型,解决了传统方......
  • HivisionIDPhotos 开源精美证件照
    马上就该考研啦,还在用某x、某xxx做证件照吗?也就用一次还得花几块钱买个会员,别当冤大头啦!最近1个月一个颠覆性的开源产品稳站GitHub榜前三,没错!他就是hivisionidphotos。博士团队开源项目,只能说太强!项目链接:https://github.com/Zeyi-Lin/HivisionIDPhotos短短1个月,竟然有1......