• R/O
  • HTTP
  • SSH
  • HTTPS

excelize: Repository summary

Go language library for reading and writing Microsoft Excel™ (XLAM / XLSM / XLSX / XLTM / XLTX) spreadsheets


Recent Commits RSS

Rev. Time Author Message
f20bbd1 2024-03-04 22:40:27 xuri master This closes #1830, closes #1831, and closes #1833 - Fix ...
963a058 2024-03-03 10:39:50 Paolo Barbolini Optimize getSharedFormula to avoid runtime.duffcopy (#18...
9d4c2e6 2024-03-01 11:12:17 陈王 This closes #1825, made AddDataValidation and DeleteData...
7b4da39 2024-02-29 10:16:39 岳晨旭 This closes #1819, closes #1827, formula function ISNUMB...
bb603b3 2024-02-27 17:43:47 helloWorld Clear slave cells value when merging cells (#1824)
688808b 2024-02-26 03:22:51 xuri v2.8.1 This closes #1819, formula calculation engine support arr...
02b84a9 2024-02-24 10:11:31 Ed This closes #1820, converted styleFillVariants from slic...
ee2ef15 2024-02-15 14:30:07 Vivek Kairi This closes #1815, cell value reading functions inherit ...
9cbe3b6 2024-02-05 01:06:38 zhukewen This closes #1807, calculation engine support date and f...
bba155e 2024-02-04 23:31:03 coolbit This closes #1805, support set chart axis font family, s...

Recently edited Tags

Name Rev. Time Author
v2.8.1 688808b 2024-02-26 03:22:51 xuri
v2.8.0 3b2b8ca 2023-08-28 01:02:25 xuri
v2.7.1 799317e 2023-04-10 01:02:20 xuri
v2.7.0 5429f13 2023-01-08 01:23:53 xuri
v2.6.1 ab12307 2022-08-21 02:09:32 xuri
v2.6.0 c1940c2 2022-04-11 01:04:00 xuri
v2.5.0 e37e060 2021-12-31 01:00:01 xuri
v2.4.1 933159f 2021-08-02 01:00:26 xuri
v2.4.0 d42834f 2021-04-19 01:00:34 xuri
v2.3.2 71829c5 2020-12-27 01:18:54 xuri
v2.3.1 89465f4 2020-09-23 00:09:34 xuri
v2.3.0 843bd24 2020-08-06 14:58:40 xuri
v2.2.0 0feb819 2020-05-11 01:06:44 xuri
v2.1.0 e51aff2 2020-02-10 01:00:37 xuri
v2.0.2 a00ba75 2019-10-09 23:11:32 xuri
v2.0.1 dc8210d 2019-07-01 08:30:51 xuri
v2.0.0 b1f632d 2019-05-02 16:59:38 xuri
v1.4.1 dea7ba0 2019-01-01 19:18:42 Rafael Barros
v1.4.0 3e004d9 2018-09-14 01:58:48 xuri
v1.3.0 eb62256 2018-05-11 11:14:18 xuri
v1.2.0 6d634ca 2017-12-01 17:52:15 Ri Xu
v1.1.0 1ec2661 2017-08-19 14:37:15 Ri Xu

Branches

Name Rev. Time Author Message
master f20bbd1 2024-03-04 22:40:27 xuri This closes #1830, closes #...

README_zh.md

Excelize logo

Build Status Code Coverage Go Report Card go.dev Licenses Donate

Excelize

简介

Excelize 是 Go 语言编写的用于操作 Office Excel 文档基础库,基于 ECMA-376,ISO/IEC 29500 国际标准。可以使用它来读取、写入由 Microsoft Excel™ 2007 及以上版本创建的电子表格文档。支持 XLAM / XLSM / XLSX / XLTM / XLTX 等多种文档格式,高度兼容带有样式、图片(表)、透视表、切片器等复杂组件的文档,并提供流式读写函数,用于处理包含大规模数据的工作簿。可应用于各类报表平台、云计算、边缘计算等系统。使用本类库要求使用的 Go 语言为 1.18 或更高版本,请注意,Go 1.21.0 中存在不兼容的更改,导致 Excelize 基础库无法在该版本上正常工作,如果您使用的是 Go 1.21.x,请升级到 Go 1.21.1 及更高版本。完整的使用文档请访问 go.dev 或查看 参考文档

快速上手

安装

go get github.com/xuri/excelize
  • 如果您使用 Go Modules 管理软件包,请使用下面的命令来安装最新版本。
go get github.com/xuri/excelize/v2

创建 Excel 文档

下面是一个创建 Excel 文档的简单例子:

package main

import (
    "fmt"

    "github.com/xuri/excelize/v2"
)

func main() {
    f := excelize.NewFile()
    defer func() {
        if err := f.Close(); err != nil {
            fmt.Println(err)
        }
    }()
    // 创建一个工作表
    index, err := f.NewSheet("Sheet2")
    if err != nil {
        fmt.Println(err)
        return
    }
    // 设置单元格的值
    f.SetCellValue("Sheet2", "A2", "Hello world.")
    f.SetCellValue("Sheet1", "B2", 100)
    // 设置工作簿的默认工作表
    f.SetActiveSheet(index)
    // 根据指定路径保存文件
    if err := f.SaveAs("Book1.xlsx"); err != nil {
        fmt.Println(err)
    }
}

读取 Excel 文档

下面是读取 Excel 文档的例子:

package main

import (
    "fmt"

    "github.com/xuri/excelize/v2"
)

func main() {
    f, err := excelize.OpenFile("Book1.xlsx")
    if err != nil {
        fmt.Println(err)
        return
    }
    defer func() {
        // 关闭工作簿
        if err := f.Close(); err != nil {
            fmt.Println(err)
        }
    }()
    // 获取工作表中指定单元格的值
    cell, err := f.GetCellValue("Sheet1", "B2")
    if err != nil {
        fmt.Println(err)
        return
    }
    fmt.Println(cell)
    // 获取 Sheet1 上所有单元格
    rows, err := f.GetRows("Sheet1")
    if err != nil {
        fmt.Println(err)
        return
    }
    for _, row := range rows {
        for _, colCell := range row {
            fmt.Print(colCell, "\t")
        }
        fmt.Println()
    }
}

在 Excel 文档中创建图表

使用 Excelize 生成图表十分简单,仅需几行代码。您可以根据工作表中的已有数据构建图表,或向工作表中添加数据并创建图表。

使用 Excelize 在 Excel 电子表格文档中创建图表

package main

import (
    "fmt"

    "github.com/xuri/excelize/v2"
)

func main() {
    f := excelize.NewFile()
    defer func() {
        if err := f.Close(); err != nil {
            fmt.Println(err)
        }
    }()
    for idx, row := range [][]interface{}{
        {nil, "Apple", "Orange", "Pear"}, {"Small", 2, 3, 3},
        {"Normal", 5, 2, 4}, {"Large", 6, 7, 8},
    } {
        cell, err := excelize.CoordinatesToCellName(1, idx+1)
        if err != nil {
            fmt.Println(err)
            return
        }
        f.SetSheetRow("Sheet1", cell, &row)
    }
    if err := f.AddChart("Sheet1", "E1", &excelize.Chart{
        Type: excelize.Col3DClustered,
        Series: []excelize.ChartSeries{
            {
                Name:       "Sheet1!$A$2",
                Categories: "Sheet1!$B$1:$D$1",
                Values:     "Sheet1!$B$2:$D$2",
            },
            {
                Name:       "Sheet1!$A$3",
                Categories: "Sheet1!$B$1:$D$1",
                Values:     "Sheet1!$B$3:$D$3",
            },
            {
                Name:       "Sheet1!$A$4",
                Categories: "Sheet1!$B$1:$D$1",
                Values:     "Sheet1!$B$4:$D$4",
            }},
        Title: []excelize.RichTextRun{
            {
                Text: "Fruit 3D Clustered Column Chart",
            },
        },
    }); err != nil {
        fmt.Println(err)
        return
    }
    // 根据指定路径保存文件
    if err := f.SaveAs("Book1.xlsx"); err != nil {
        fmt.Println(err)
    }
}

向 Excel 文档中插入图片

package main

import (
    "fmt"
    _ "image/gif"
    _ "image/jpeg"
    _ "image/png"

    "github.com/xuri/excelize/v2"
)

func main() {
    f, err := excelize.OpenFile("Book1.xlsx")
    if err != nil {
        fmt.Println(err)
        return
    }
    defer func() {
        // 关闭工作簿
        if err := f.Close(); err != nil {
            fmt.Println(err)
        }
    }()
    // 插入图片
    if err := f.AddPicture("Sheet1", "A2", "image.png", nil); err != nil {
        fmt.Println(err)
    }
    // 在工作表中插入图片,并设置图片的缩放比例
    if err := f.AddPicture("Sheet1", "D2", "image.jpg",
        &excelize.GraphicOptions{ScaleX: 0.5, ScaleY: 0.5}); err != nil {
        fmt.Println(err)
    }
    // 在工作表中插入图片,并设置图片的打印属性
    enable, disable := true, false
    if err := f.AddPicture("Sheet1", "H2", "image.gif",
        &excelize.GraphicOptions{
            PrintObject:     &enable,
            LockAspectRatio: false,
            OffsetX:         15,
            OffsetY:         10,
            Locked:          &disable,
        }); err != nil {
        fmt.Println(err)
    }
    // 保存工作簿
    if err = f.Save(); err != nil {
        fmt.Println(err)
    }
}

社区合作

欢迎您为此项目贡献代码,提出建议或问题、修复 Bug 以及参与讨论对新功能的想法。 XML 符合标准: part 1 of the 5th edition of the ECMA-376 Standard for Office Open XML

开源许可

本项目遵循 BSD 3-Clause 开源许可协议,访问 https://opensource.org/licenses/BSD-3-Clause 查看许可协议文件。

Excel 徽标是 Microsoft Corporation 的商标,项目的图片是一种改编。

gopher.{ai,svg,png} 由 Takuya Ueda 创作,遵循 Creative Commons 3.0 Attributions license 创作共用授权条款。

Show on old repository browser