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
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...