Go操作Excel | 青训营笔记

234 阅读3分钟

Excelize 是 Go 语言编写的用于操作 Office Excel 文档类库,基于 ECMA-376 Office OpenXML 标准。可以使用它来读取、写入由 Microsoft Excel™ 2007 及以上版本创建的 XLSX 文档。相比较其他的开源类库,Excelize 支持写入原本带有图片(表)、透视表和切片器等复杂样式的文档,还支持向 Excel 文档中插入图片与图表,并且在保存后不会丢失文档原有样式,可以应用于各类报表系统中。使用本类库要求使用的 Go 语言为 1.15 或更高版本,完整的 API 使用文档请访问 go.dev 或查看参考文档

GitHubgithub.com/xuri/exceli…

性能数据

下面的性能数据展示了创建 N 行 50 列工作表所执行时间和内存使用情况,其中单元格的值均为 6 个文本字符。测试环境基于普通个人计算机 (OS: macOS Big Sur version 11.2, CPU: 3.4 GHz Intel Core i5, RAM: 16 GB 2400 MHz DDR4, HDD: 1 TB, Go Version: go1.15.7 darwin/amd64, Commit: 23c73ab)。具体数据会因机器而异,但趋势应该是一样的。

image.png

安装

go get github.com/xuri/excelize/v2

创建 XLSX


    package main

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

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

读取已有文档

    package main

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

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

向 Excel 中插入图表

使用 Go 语言通过 Excelize 向 Excel 中插入图表


    package main

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

    func main() {
        categories := map[string]string{"A2": "Small", "A3": "Normal", "A4": "Large", "B1": "Apple", "C1": "Orange", "D1": "Pear"}
        values := map[string]int{"B2": 2, "C2": 3, "D2": 3, "B3": 5, "C3": 2, "D3": 4, "B4": 6, "C4": 7, "D4": 8}
        f := excelize.NewFile()
        for k, v := range categories {
            f.SetCellValue("Sheet1", k, v)
        }
        for k, v := range values {
            f.SetCellValue("Sheet1", k, v)
        }
        if err := f.AddChart("Sheet1", "E1", `{"type":"col3DClustered","series":[{"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":{"name":"Fruit 3D Clustered Column Chart"}}`); err != nil {
            println(err.Error())
            return
        }
        // 根据指定路径保存文件
        if err := f.SaveAs("Book1.xlsx"); err != nil {
            println(err.Error())
        }
    }

向 Excel 中插入图片

    package main

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

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

    func main() {
        f, err := excelize.OpenFile("Book1.xlsx")
        if err != nil {
            println(err.Error())
            return
        }
        // 插入图片
        if err := f.AddPicture("Sheet1", "A2", "image.png", ""); err != nil {
            println(err.Error())
        }
        // 在工作表中插入图片,并设置图片的缩放比例
        if err := f.AddPicture("Sheet1", "D2", "image.jpg", `{"x_scale": 0.5, "y_scale": 0.5}`); err != nil {
            println(err.Error())
        }
        // 在工作表中插入图片,并设置图片的打印属性
        if err := f.AddPicture("Sheet1", "H2", "image.gif", `{"x_offset": 15, "y_offset": 10, "print_obj": true, "lock_aspect_ratio": false, "locked": false}`); err != nil {
            println(err.Error())
        }
        // 保存文件
        if err = f.Save(); err != nil {
            println(err.Error())
        }
    }

总结

以上功能只需灵活扩展后基本上就可以覆盖大部分业务了,但是有一点需要注意,在2.5使用Http协议将数据转换为Excel文件并下载这个操作中,需要将文件进行重命名,这个名称可以自定义,也可以由服务端指定,但是需要以相关文件类型的名称做后缀,否则会输出zip压缩文件,很难看懂。

网上有一个详细介绍excelize使用的中文文档,总结挺全面的,地址:xuri.me/excelize/zh…

参考

zhuanlan.zhihu.com/p/33417413

studygolang.com/articles/98…