Excelize 正在参加 2020 年度 OSC 中国开源项目评选,请投票支持!
Excelize 在 2020 年度 OSC 中国开源项目评选 中已获得 {{ projectVoteCount }} 票,请投票支持!
投票让它出道
已投票
Excelize 获得 2020 年度 OSC 中国开源项目评选「最佳人气项目」 !
Excelize 获得 2020 年度 OSC 中国开源项目评选「最佳人气项目」「最积极运营项目」 !
Excelize 获得 2020 年度 OSC 中国开源项目评选「最积极运营项目」 !

软件简介

Excelize Go 语言 Excel 基础库

Excelize 是 Go 语言编写的用于操作 Office Excel 文档基础库,基于 ECMA-376,ISO/IEC 29500 国际标准。可以使用它来读取、写入由 Microsoft Excel™ 2007 及以上版本创建的电子表格文档。支持 XLSX / XLSM / XLTM 等多种文档格式,高度兼容带有样式、图片(表)、透视表、切片器等复杂组件的文档,并提供流式读写 API,用于处理包含大规模数据的工作簿。可应用于各类报表平台、云计算、边缘计算等系统。入选 2020 Gopher China - Go 领域明星开源项目 (GSP)、2018 开源中国码云 Gitee 最有价值开源项目 GVP,目前已成为 Go 语言最受欢迎的 Excel 文档基础库。

知名用户

Go Excelize 知名用户

安装

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

创建 Excel 文档

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

package main

import (
    "fmt"

    "github.com/360EntSecGroup-Skylar/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 {
        fmt.Println(err)
    }
}

读取 Excel 文档

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

package main

import (
    "fmt"

    "github.com/360EntSecGroup-Skylar/excelize/v2"
)

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

在 Excel 文档中创建图表

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

使用 Excelize 向 Excel 文档插入图片

package main

import (
    "fmt"

    "github.com/360EntSecGroup-Skylar/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 {
        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/360EntSecGroup-Skylar/excelize/v2"
)

func main() {
    f, err := excelize.OpenFile("Book1.xlsx")
    if err != nil {
        fmt.Println(err)
        return
    }
    // 插入图片
    if err := f.AddPicture("Sheet1", "A2", "image.png", ""); err != nil {
        fmt.Println(err)
    }
    // 在工作表中插入图片,并设置图片的缩放比例
    if err := f.AddPicture("Sheet1", "D2", "image.jpg", `{"x_scale": 0.5, "y_scale": 0.5}`); err != nil {
        fmt.Println(err)
    }
    // 在工作表中插入图片,并设置图片的打印属性
    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 {
        fmt.Println(err)
    }
    // 保存文件
    if err = f.Save(); err != nil {
        fmt.Println(err)
    }
}
展开阅读全文

代码

的 Gitee 指数为
超过 的项目

评论 (8)

加载中
xuri软件作者
提前剧透一下,#Excelize# 已入选 2020 GopherChina GSP - Go 领域最卓越明星项目,有参加本次大会的朋友,本周六在上海我们现场见!https://gopherchina.org
2020/11/20 08:33
回复
举报
打分: 力荐
好用
2020/11/12 11:16
回复
举报
打分: 力荐
棒棒哒
2020/10/30 15:52
回复
举报
打分: 力荐
2020/10/28 10:28
回复
举报
优秀的产品,需要更多的人知道
2020/10/27 17:39
回复
举报
嘤嘤嘤
2020/10/27 16:19
回复
举报
6666
2019/11/28 12:29
回复
举报

引用来自“色魔张大妈”的评论

很好
好名字
2019/01/03 15:46
回复
举报
打分: 推荐
很好
2018/03/20 23:11
回复
举报
更多评论
发表了资讯
04/19 01:10

Excelize 2.4.0 正式版发布,新增 152 项公式函数支持

Excelize 是 Go 语言编写的用于操作 Office Excel 文档基础库,基于 ECMA-376,ISO/IEC 29500 国际标准。可以使用它来读取、写入由 Microsoft Excel™ 2007 及以上版本创建的电子表格文档。支持 XLSX / XLSM / XLTM 等多种文档格式,高度兼容带有样式、图片(表)、透视表、切片器等复杂组件的文档,并提供流式读写 API,用于处理包含大规模数据的工作簿。可应用于各类报表平台、云计算、边缘计算等系统。入选 2020 Gopher China ...

1
6
发表了资讯
02/20 00:23

Excelize v2.3.1 已经发布,Go 语言(golang) Excel (xlsx) 电子表格文档基础库

Excelize v2.3.1 已经发布,这是一个 Go 语言(golang) Excel (xlsx) 电子表格文档基础库。 此版本更新内容包括: 我们很高兴地宣布发布 2.3.1 版本,该版本包含了多项新功能和错误修复。 有关更改的摘要,请参阅 Release Notes。完整的更改列表可查看 change log。 Release Notes 此版本中最显著的变化包括: 新增功能 支持打开带有基于 ECMA-376 文档加密标准密码保护的电子表格文档,相关 issue #199 增加工作表规范与限制 扩...

0
8
发表于开发技能专区
01/04 00:25

Excelize 发布 2.3.2 版本,Go 语言 Excel 文档基础库

Excelize 是 Go 语言编写的用于操作 Office Excel 文档基础库,基于 ECMA-376,ISO/IEC 29500 国际标准。可以使用它来读取、写入由 Microsoft Excel™ 2007 及以上版本创建的电子表格文档。支持 XLSX / XLSM / XLTM 等多种文档格式,高度兼容带有样式、图片(表)、透视表、切片器等复杂组件的文档,并提供流式读写 API,用于处理包含大规模数据的工作簿。可应用于各类报表平台、云计算、边缘计算等系统。入选 2020 Gopher China ...

1
6
发表于软件架构专区
2020/09/23 00:24

Excelize 发布 2.3.1 版本,Go 语言 Excel 文档基础库

Excelize 是 Go 语言编写的用于操作 Office Excel 文档基础库,基于 ECMA-376,ISO/IEC 29500 国际标准。可以使用它来读取、写入由 Microsoft Excel™ 2007 及以上版本创建的电子表格文档。支持 XLSX / XLSM / XLTM 等多种文档格式,高度兼容带有样式、图片(表)、透视表、切片器等复杂组件的文档,并提供流式读写 API,用于处理包含大规模数据的工作簿。可应用于各类报表平台、云计算、边缘计算等系统。入选 2018 开源中国码云 ...

3
8
发表于服务端专区
2020/08/10 01:14

Excelize 发布 2.3.0 版本,Go 语言 Excel 文档基础库

Excelize 是 Go 语言编写的用于操作 Office Excel 文档基础库,基于 ECMA-376,ISO/IEC 29500 国际标准。可以使用它来读取、写入由 Microsoft Excel™ 2007 及以上版本创建的电子表格文档。支持 XLSX / XLSM / XLTM 等多种文档格式,高度兼容带有样式、图片(表)、透视表、切片器等复杂组件的文档,并提供流式读写 API,用于处理包含大规模数据的工作簿。可应用于各类报表平台、云计算、边缘计算等系统。入选 2018 开源中国码云 ...

1
11
发表于开发技能专区
2020/05/11 01:29

Excelize 发布 2.2.0 版本,Go 语言 Excel 文档基础库

Excelize 是 Go 语言编写的用于操作 Office Excel 文档基础库,基于 ECMA-376,ISO/IEC 29500 国际标准。可以使用它来读取、写入由 Microsoft Excel™ 2007 及以上版本创建的电子表格文档。支持 XLSX / XLSM / XLTM 等多种文档格式,高度兼容带有样式、图片(表)、透视表、切片器等复杂组件的文档,并提供流式读写 API,用于处理包含大规模数据的工作簿。可应用于各类报表平台、云计算、边缘计算等系统。入选 2018 开源中国码云 ...

2
7
发表于服务端专区
2020/02/10 00:13

Excelize 发布 2.1.0 版本,Go 语言 Excel 文档基础库

Excelize 是 Go 语言编写的用于操作 Office Excel 文档类库,基于 ECMA-376 Office OpenXML 标准。可以使用它来读取、写入由 Microsoft Excel™ 2007 及以上版本创建的 XLSX 文档。相比较其他的开源类库,Excelize 支持写入原本带有图片(表)、透视表和切片器等复杂样式的文档,还支持向 Excel 文档中插入图片与图表,并且在保存后不会丢失文档原有样式,可以应用于各类报表系统中。入选 2018 开源中国码云 Gitee 最有价值开源项...

2
16
发表于软件架构专区
2019/10/09 22:43

Excelize 发布 2.0.2 版本,Go 语言 Excel 基础库

Excelize 是 Go 语言编写的一个用来操作 Office Excel 文档类库,基于 ECMA-376 OOXML Spec。可以使用它来读取、写入 XLSX 文件,相比较其他的开源类库,Excelize 支持操作带有数据透视表、切片器、图表与图片的 Excel 并支持向 Excel 中插入图片与创建简单图表,可应用于各种报表系统中。Excelize 作为 2018 开源中国 Gitee 最有价值开源项目 GVP,现已成为 Go 语言最受欢迎的 Excel 文档基础库。 2019年10月9日,社区正式发布...

7
31
发表于软件架构专区
2019/07/01 07:41

Excelize 发布 2.0.1 版本,Go 语言 Office Excel 基础库

Excelize 是 Go 语言编写的用于操作 Office Excel 文档类库,基于 ECMA-376 Office OpenXML 标准。可以使用它来读取、写入由 Microsoft Excel™ 2007 及以上版本创建的 XLSX 文档。相比较其他的开源类库,Excelize 支持写入原本带有图片(表)、透视表和切片器等复杂样式的文档,还支持向 Excel 文档中插入图片与图表,并且在保存后不会丢失文档原有样式,可以应用于各类报表系统中。入选 2018 开源中国码云 Gitee 最有价值开源项...

0
10
发表于服务端专区
2019/04/23 13:53

Go 语言 Excel 类库 Excelize 2.0.0 版本发布

Excelize 是 Go 语言编写的用于操作 Office Excel 文档类库,基于 ECMA-376 Office OpenXML 标准。可以使用它来读取、写入由 Microsoft Excel™ 2007 及以上版本创建的 XLSX 文档。相比较其他的开源类库,Excelize 支持写入原本带有图片(表)、透视表和切片器等复杂样式的文档,还支持向 Excel 文档中插入图片与图表,并且在保存后不会丢失文档原有样式,可以应用于各类报表系统中。 2019年4月23日, 社区正式发布了 2.0.0 版本,...

3
57
发表于AI & 大数据专区
2019/01/03 12:23

Go 语言 Excel 类库 Excelize 1.4.1 版本发布

Excelize 是 Go 语言编写的用于操作 Office Excel 文档类库,基于 ECMA-376 Office OpenXML 标准。可以使用它来读取、写入由 Microsoft Excel™ 2007 及以上版本创建的 XLSX 文档。相比较其他的开源类库,Excelize 支持写入原本带有图片(表)、透视表和切片器等复杂样式的文档,还支持向 Excel 文档中插入图片与图表,并且在保存后不会丢失文档原有样式,可以应用于各类报表系统中。 2019年1月3日, 社区正式发布了 1.4.1 ...

3
34
没有更多内容
加载失败,请刷新页面
点击加载更多
加载中
下一页
发表了博客
01/07 12:20

首期 Go 开源说实录:Excelize 开源背后的故事

首期主题:Excelize 在 Go 中国社区的首期 Go 开源说线上活动中,开源项目 Excelize 的作者续日带来了《Excelize 开源背后的故事》主题分享。 作者介绍 续日,软件工程师,专注于 Go 语言实践、中间件研发与大规模数据处理。目前就职于阿里巴巴,曾就职于百度、奇虎 360 等公司,前百度 Go 语言编程委员会成员,在百度期间从事内部 Go 语言开发框架和代码规范的相关工作。他热爱开源,会把一些开源项目发布在他的 GitHub 上:h...

0
0
01/05 18:21

首期 Go 开源说实录:Excelize 开源背后的故事

首期主题:Excelize 在 Go 中国社区的首期 Go 开源说线上活动中,开源项目 Excelize 的作者续日带来了《Excelize 开源背后的故事》主题分享。 作者介绍 续日,软件工程师,专注于 Go 语言实践、中间件研发与大规模数据处理。目前就职于阿里巴巴,曾就职于百度、奇虎 360 等公司,前百度 Go 语言编程委员会成员,在百度期间从事内部 Go 语言开发框架和代码规范的相关工作。他热爱开源,会把一些开源项目发布在他的 GitHub 上:h...

0
1
发表了博客
2020/08/17 07:45

Excelize 发布 2.3.0 版本,Go 语言 Excel 文档基础库

Excelize 是 Go 语言编写的用于操作 Office Excel 文档基础库,基于 ECMA-376,ISO/IEC 29500 国际标准。可以使用它来读取、写入由 Microsoft Excel™ 2007 及以上版本创建的电子表格文档。支持 XLSX / XLSM / XLTM 等多种文档格式,高度兼容带有样式、图片(表)、透视表、切片器等复杂组件的文档,并提供流式读写 API,用于处理包含大规模数据的工作簿。可应用于各类报表平台、云计算、边缘计算等系统。入选 2018 开源中国码云 ...

0
0
发表了博客
2020/04/05 16:35

Excelize 发布 2.1.0 版本, Go 语言最受欢迎的 Excel 基础库

Excelize 是 Go 语言编写的用于操作 Office Excel 文档类库,基于 ECMA-376 Office Open XML 标准。可以使用它来读取、写入由 Microsoft Excel™ 2007 及以上版本创建的 XLSX 文档。相比较其他的开源类库,Excelize 支持写入原本带有图片(表)、透视表和切片器等复杂样式的文档,还支持向 Excel 文档中插入图片与图表,并且在保存后不会丢失文档原有样式,可以应用于各类报表系统中。入选 2018 开源中国码云 Gitee 最有价值开源项...

0
0
发表了博客
2020/12/16 18:49

Go 开源说强势来袭,首期带来 Excelize 开源背后的故事

写在前面 随着Go在中国越来越多的应用场景,我们中国的Gopher开发的开源项目也越来越多,目前在github上面有大量的Go写的开源项目,但是很多时候一个好的项目让别人获知,同时让大家了解背后的设计设计原理,其实是很困难的一件事情。 基于这样的背景,我们GoCN社区推出这个《Go 开源说》,每两周会播出一期。希望通过这样的平台帮助到我们开源的作者,有一个平台去推广我们的开源项目,第二说说背后的设计原理和理念,产品优越...

0
1
发表了博客
2020/12/26 17:17

golang利用excelize链接数据库生成excel表

package main import ( "fmt" "strconv" //"pkg/mod/github.com/360!ent!sec!group-!skylar/excelize@v1.4.1" "github.com/360EntSecGroup-Skylar/excelize" _ "github.com/go-sql-driver/mysql" "github.com/jinzhu/gorm" "log" ) var DB1 *gorm.DB type User struct { Rechargedate string `json:"rechargedate"` Rechargetime string `json:"rechargetime"` Rechargezone string...

0
0
发表了博客
2020/12/18 13:56

Go 开源说强势来袭,首期带来 Excelize 开源背后的故事

写在前面 随着Go在中国越来越多的应用场景,我们中国的Gopher开发的开源项目也越来越多,目前在github上面有大量的Go写的开源项目,但是很多时候一个好的项目让别人获知,同时让大家了解背后的设计设计原理,其实是很困难的一件事情。 基于这样的背景,我们GoCN社区推出这个《Go 开源说》,每两周会播出一期。希望通过这样的平台帮助到我们开源的作者,有一个平台去推广我们的开源项目,第二说说背后的设计原理和理念,产品优越...

0
0
发表了博客
01/23 12:22

Excelize 2.3.2 发布, Go 语言 Excel 文档基础库, 2021 年首个更新

Excelize 是 Go 语言编写的用于操作 Office Excel 文档基础库,基于 ECMA-376,ISO/IEC 29500 国际标准。可以使用它来读取、写入由 Microsoft Excel™ 2007 及以上版本创建的电子表格文档。支持 XLSX / XLSM / XLTM 等多种文档格式,高度兼容带有样式、图片(表)、透视表、切片器等复杂组件的文档,并提供流式读写 API,用于处理包含大规模数据的工作簿。可应用于各类报表平台、云计算、边缘计算等系统。入选 2020 Gopher China ...

0
0
没有更多内容
加载失败,请刷新页面
点击加载更多
加载中
下一页
暂无内容
8 评论
192 收藏
分享
OSCHINA
登录后可查看更多优质内容
返回顶部
顶部