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 檔案基礎庫。
2023年4月10日,社區正式釋出了 2.7.1 版本,該版本包含了多項新增功能、錯誤修復和兼容性提升優化。下面是有關該版本更新內容的摘要,完整的更改列表可查看 changelog。
此版本中最顯著的變化包括:
ChartLine
數據類型中的 Color
字段RichTextRun
數據類型代替 ShapeParagraph
Fill
代替 Shape
數據類型中的 Color
字段AutoFilterListOptions
TableOptions
重命名為 Table
AddChart
改為使用 ChartType
類型枚舉值指定圖表類型func (f *File) AutoFilter(sheet, rangeRef string, opts *AutoFilterOptions) error
修改為 func (f *File) AutoFilter(sheet, rangeRef string, opts []AutoFilterOptions) error
func (f *File) AddPictureFromBytes(sheet, cell, name, extension string, file []byte, opts *GraphicOptions) error
修改為 func (f *File) AddPictureFromBytes(sheet, cell string, pic *Picture) error
func (f *File) GetPicture(sheet, cell string) (string, []byte, error)
修改為 func (f *File) GetPictures(sheet, cell string) ([]Picture, error)
func (f *File) AddVBAProject(bin string) error
修改為 func (f *File) AddVBAProject(file []byte) error
func (f *File) GetComments() (map[string][]Comment, error)
修改為 func (f *File) GetComments(sheet string) ([]Comment, error)
func (f *File) AddTable(sheet, rangeRef string, opts *TableOptions) error
修改為 func (f *File) AddTable(sheet string, table *Table) error
func (sw *StreamWriter) AddTable(rangeRef string, opts *TableOptions) error
修改為 func (sw *StreamWriter) AddTable(table *Table) error
SetSheetDimension
與 GetSheetDimension
以支持設定與獲取工作表已用區域,相關 issue #1463
NewStyle
現已支持 17 種漸變填充樣式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
GetCellHyperLink
函數支持獲取合併存儲格中的超鏈接ChartType
以表示圖表類型枚舉感謝 Excelize 的所有貢獻者,以下是為此版本提交代碼的貢獻者列表: