Excelize 發佈 2.7.1 版本,Go 語言 Excel 文檔基礎庫

来源:https://www.cnblogs.com/xuri/archive/2023/04/10/excelize_v2_7_1.html
-Advertisement-
Play Games

Excelize 是 Go 語言編寫的用於操作 Office Excel 文檔基礎庫,2023年4月10日,社區正式發佈了 2.7.1 版本,該版本包含了多項新增功能、錯誤修複和相容性提升優化。 ...


Excelize 發佈 2.7.1 版本,Go 語言 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 年開源中國碼雲最有價值開源項目 GVP (Gitee Most Valuable Project),目前已成為 Go 語言最受歡迎的 Excel 文檔基礎庫。

開源代碼

GitHub: github.com/xuri/excelize

Gitee: gitee.com/xurime/excelize

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

2023年4月10日,社區正式發佈了 2.7.1 版本,該版本包含了多項新增功能、錯誤修複和相容性提升優化。下麵是有關該版本更新內容的摘要,完整的更改列表可查看 changelog

此版本中最顯著的變化包括:

相容性提示

  • 移除了 ChartLine 數據類型中的 Color 欄位
  • 使用 RichTextRun 數據類型代替 ShapeParagraph
  • 使用 Fill 代替 Shape 數據類型中的 Color 欄位
  • 移除了已導出的數據類型 AutoFilterListOptions
  • 將數據類型 TableOptions 重命名為 Table
  • 添加圖表函數 AddChart 改為使用 ChartType 類型枚舉值指定圖表類型
  • 修改了 7 個函數的簽名,具體更改詳見官方文檔中的更新說明

新增功能

  • 新增函數 SetSheetDimensionGetSheetDimension 以支持設置與獲取工作表已用區域,相關 issue #1463
  • 創建樣式函數 NewStyle 現已支持 17 種漸變填充樣式
  • 增加創建樣式數量上限至 65430
  • 通過 AddPicture 添加圖片時,現已允許插入 BMP 格式圖片
  • 函數 GetPictures 支持讀取被添加至同一單元格中的多張圖片
  • 設置條件格式函數 SetConditionalFormat 支持設置帶有“如果為真則停止”和“圖標集”條件的條件格式規則
  • 設置條件格式函數 SetConditionalFormat 支持設置在條件格式中使用帶有純色填充樣式的數據條,並支持指定數據條的顏色,相關 issue #1462
  • 添加圖表函數 AddChart 支持設置圖表中各個數據系列使用自定義填充顏色,相關 issue #1474
  • 添加圖表函數 AddChart 支持設置氣泡圖圖表中各個系列氣泡的大小
  • 添加圖表函數 AddChart 支持設置子母餅圖和複合條餅圖中第二繪圖區域的數據系列
  • 添加圖表函數 AddChart 支持為圖表中數據標簽設置自定義數字格式,相關 issue #1499
  • 創建表格函數 AddTable 支持在創建表格時指定是否包含標題行
  • 創建表格函數 AddTable 創建表格時增加對錶格名稱的校驗,並導出了錯誤常量 ErrTableNameLength,相關 issue #1468
  • 函數 AutoFilter 支持為篩選範圍內的多個列設置篩選條件
  • 計算單元格的值函數 CalcCellValue 現已支持指定是否為公式計算結果應用數字格式
  • 計算單元格的值函數 CalcCellValue 對於以下公式函數加入了雙位元組字元的支持:LEFT, LEN, LENB, MID, MIDB, RIGHT 和 RIGHTB,相關 issue #1476
  • 計算單元格的值函數 CalcCellValue 函數對於存在錯誤的公式將在計算結果中返回公式錯誤代碼,並將詳細錯誤信息在 error 數據類型的返回值中返回,相關 issue #1490
  • 對輸入圖片文件的擴展名調整為大小寫不敏感,相關 issue #1503
  • 使用流式寫入器流式按行賦值時,對於值為 nil 的單元格將會跳過生成該單元格,相關 issue #756
  • 獲取超鏈接 GetCellHyperLink 函數支持讀取合併單元格中的超鏈接
  • 添加了新的導出類型 ChartType 以表示圖表類型枚舉

相容性提升

  • 相容帶有函數組的工作簿
  • 相容帶有嚴格模式 XML 命名空間地址的工作簿主題,相關 issue #1447
  • 提高了與文檔內部不含工作簿關係部件工作簿的相容性,以修複打開此類工作簿可能出現的 panic

問題修複

  • 修複了特定情況下讀取日期時間類型單元格的值存在精度誤差的問題
  • 修複了特定情況下當修改原本存儲了日期時間類型的單元格為文本類型值,修改後單元格數據類型有誤的問題,解決 issue #1464
  • 修複了部分情況下公式計算結果為空的問題,解決 issue #1469
  • 修複了設置數據條類型條件格式時,指定自定義最大/最小值無效的問題,解決 issue #1492
  • 修複了打開行高或列寬為 0 的工作表,保存後行高列寬設置失效的問題,解決 issue #1461
  • 提高了讀取帶有空白字元共用字元串表索引值的相容性,解決 issue #1508

性能優化

  • 提高了應用帶有自定義月份數字格式的速度,相關 issue #1455
  • 大幅提高了對於帶有合併單元格工作表的處理速度,相關 issue #1448

其他

  • Go Excelize 提供了支持 WebAssembly / Javascript 環境的 excelize-wasm NPM 包
  • Go Modules 依賴模塊更新
  • 單元測試與文檔更新
  • 優化內部變數與函數命名
  • 包含簡體中文、英語、法語、俄語、日語、韓語、阿拉伯語、德語和西班牙語的多國語言文檔網站更新

致謝

感謝 Excelize 的所有貢獻者,以下是為此版本提交代碼的貢獻者列表:

  • liron-l (Liron Levin)
  • nathj07 (Nathan Davies)
  • Josh-Weston (Josh Weston)
  • jaby
  • FlowingSPDG (Shugo Kawamura)
  • barismar (Baris Mar Aziz)
  • doingNobb (張濤)
  • rpoetrap (Rizki Putra)
  • huangshaokun
  • CHANTXU64 (ChantXu64)
  • playGitboy
作者: Ri XuRi Xu's Blog on 博客園
出處:https://www.cnblogs.com/xuri
作品Ri Xu 創作,採用知識共用署名-非商業性使用-禁止演繹 2.5 中國大陸許可協議進行許可。 歡迎轉載,但任何轉載必須保留完整文章,在顯要地方顯示署名以及原文鏈接。如您有任何疑問或者授權方面的協商,請 給我留言
您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 在開發中我們有時候需要每隔 一段時間發送一次電子郵件,或者在某個特定的時間進行發送郵件,無需手動去操作,基於這樣的情況下我們需要用到了定時任務,一般可以寫個定時器,來完成相應的需求,在 node.js 中自已實現也非常容易,接下來要介紹的是node-schedule來完成定時任務 ...
  • @Configuration 標註在類上,啟動 Spring 會自動掃描@Configuration註解的類,將其註冊到IOC容器並實例化bean對象。如果在@Configuration註解的類中使用@Bean註解某個類對象的方法,Spring也會自動將註解了@Bean的方法註冊到IOC容器,併進行 ...
  • 何為請求限流? 請求限流是一種控制API或其他Web服務的流量的技術。它的目的是限制客戶端對伺服器發出的請求的數量或速率,以防止伺服器過載或響應時間變慢,從而提高系統的可用性和穩定性。 中小型項目請求限流的需求 按IP、用戶、全局限流 基於不同實現的限流設計(基於Redis或者LRU緩存) 基於註解 ...
  • 最近在開發過程中遇到一個sqlalchemy lost connection的報錯,記錄解決方法。 報錯信息 python後端開發,使用的框架是Fastapi + sqlalchemy。在一個介面請求中報錯如下: [2023-03-24 06:36:35 +0000] [217] [ERROR] E ...
  • 1、原視頻地址 https://www.bilibili.com/video/BV1ME411A73k/?spm_id_from=333.1007.top_right_bar_window_custom_collection.content.click&vd_source=33b50a4dd201d ...
  • P1 Collection介面和常用方法 一、Collection介面實現類的特點 public interface Collection extends Iterable Collection實現子類可以存放多個元素,每個元素可以是Object。 有些Collection的實現類,可以存放重覆的元 ...
  • SpringCloud Ribbon 1.Ribbon介紹 1.1Ribbon是什麼? 官網地址:Netflix/ribbon: Ribbon(github.com) SpringCloud Ribbon 是基於 Netflix Ribbon 實現的一套客戶端負載均衡的工具 Ribbon 主要功能是 ...
  • 前言 在上一篇文章中,我們介紹了&運算符的基礎用法,本篇文章,我們將介紹& 運算符的一些高級用法。 一、人物簡介 第一位閃亮登場,有請今後會一直教我們C語言的老師 —— 自在。 第二位上場的是和我們一起學習的小白程式猿 —— 逍遙。 二、位掩碼 位掩碼是一種用於按位操作的技術 它通過使用一個二進位數 ...
一周排行
    -Advertisement-
    Play Games
  • 前言 本文介紹一款使用 C# 與 WPF 開發的音頻播放器,其界面簡潔大方,操作體驗流暢。該播放器支持多種音頻格式(如 MP4、WMA、OGG、FLAC 等),並具備標記、實時歌詞顯示等功能。 另外,還支持換膚及多語言(中英文)切換。核心音頻處理採用 FFmpeg 組件,獲得了廣泛認可,目前 Git ...
  • OAuth2.0授權驗證-gitee授權碼模式 本文主要介紹如何筆者自己是如何使用gitee提供的OAuth2.0協議完成授權驗證並登錄到自己的系統,完整模式如圖 1、創建應用 打開gitee個人中心->第三方應用->創建應用 創建應用後在我的應用界面,查看已創建應用的Client ID和Clien ...
  • 解決了這個問題:《winForm下,fastReport.net 從.net framework 升級到.net5遇到的錯誤“Operation is not supported on this platform.”》 本文內容轉載自:https://www.fcnsoft.com/Home/Sho ...
  • 國內文章 WPF 從裸 Win 32 的 WM_Pointer 消息獲取觸摸點繪製筆跡 https://www.cnblogs.com/lindexi/p/18390983 本文將告訴大家如何在 WPF 裡面,接收裸 Win 32 的 WM_Pointer 消息,從消息裡面獲取觸摸點信息,使用觸摸點 ...
  • 前言 給大家推薦一個專為新零售快消行業打造了一套高效的進銷存管理系統。 系統不僅具備強大的庫存管理功能,還集成了高性能的輕量級 POS 解決方案,確保頁面載入速度極快,提供良好的用戶體驗。 項目介紹 Dorisoy.POS 是一款基於 .NET 7 和 Angular 4 開發的新零售快消進銷存管理 ...
  • ABP CLI常用的代碼分享 一、確保環境配置正確 安裝.NET CLI: ABP CLI是基於.NET Core或.NET 5/6/7等更高版本構建的,因此首先需要在你的開發環境中安裝.NET CLI。這可以通過訪問Microsoft官網下載並安裝相應版本的.NET SDK來實現。 安裝ABP ...
  • 問題 問題是這樣的:第三方的webapi,需要先調用登陸介面獲取Cookie,訪問其它介面時攜帶Cookie信息。 但使用HttpClient類調用登陸介面,返回的Headers中沒有找到Cookie信息。 分析 首先,使用Postman測試該登陸介面,正常返回Cookie信息,說明是HttpCli ...
  • 國內文章 關於.NET在中國為什麼工資低的分析 https://www.cnblogs.com/thinkingmore/p/18406244 .NET在中國開發者的薪資偏低,主要因市場需求、技術棧選擇和企業文化等因素所致。歷史上,.NET曾因微軟的閉源策略發展受限,儘管後來推出了跨平臺的.NET ...
  • 在WPF開發應用中,動畫不僅可以引起用戶的註意與興趣,而且還使軟體更加便於使用。前面幾篇文章講解了畫筆(Brush),形狀(Shape),幾何圖形(Geometry),變換(Transform)等相關內容,今天繼續講解動畫相關內容和知識點,僅供學習分享使用,如有不足之處,還請指正。 ...
  • 什麼是委托? 委托可以說是把一個方法代入另一個方法執行,相當於指向函數的指針;事件就相當於保存委托的數組; 1.實例化委托的方式: 方式1:通過new創建實例: public delegate void ShowDelegate(); 或者 public delegate string ShowDe ...