Go language library for reading and writing Microsoft Excel™ (XLAM / XLSM / XLSX / XLTM / XLTX) spreadsheets
Rev. | 时间 | 作者 | Message |
---|---|---|---|
a34c81e | 2023-03-20 10:17:28 | ChantXu64 | master v2 This closes #1448, speed up for checking merged cells (... |
478b528 | 2023-03-19 21:29:35 | ![]() |
Breaking changes: changed the function signature for 2 ex... |
7631fd0 | 2023-03-18 21:45:34 | ![]() |
This closes #1499, support to set number format for chart... |
e394f01 | 2023-03-15 10:17:30 | Rizki Putra | This update the return value for the `CalcCellValue` fun... |
0d193c7 | 2023-03-14 01:58:20 | ![]() |
This closes #1492, fix data bar min/max value doesn't work |
dc3bf33 | 2023-03-04 01:07:04 | ![]() |
Breaking change: changed the third parameter for the `Add... |
f707b2d | 2023-03-01 14:25:17 | 张涛 | This closes #1484, fix the formula calc result issue (#1... |
65a53b3 | 2023-02-27 01:05:36 | ![]() |
Breaking changes: replace the type `ShapeParagraph` with... |
669c432 | 2023-02-24 01:18:10 | Baris Mar Aziz | This fixes #756, made stream writer skip set cell value ... |
94e86dc | 2023-02-22 23:46:36 | ![]() |
This renamed conditional format type `iconSet` to `icon_s... |
名称 | Rev. | 时间 | 作者 |
---|---|---|---|
v2.6.0 | c1940c2 | 2022-04-11 01:04:00 | ![]() |
v2.5.0 | e37e060 | 2021-12-31 01:00:01 | ![]() |
v2.4.1 | 933159f | 2021-08-02 01:00:26 | ![]() |
v2.4.0 | d42834f | 2021-04-19 01:00:34 | ![]() |
v2.3.2 | 71829c5 | 2020-12-27 01:18:54 | ![]() |
v2.3.1 | 89465f4 | 2020-09-23 00:09:34 | ![]() |
v2.3.0 | 843bd24 | 2020-08-06 14:58:40 | ![]() |
v2.2.0 | 0feb819 | 2020-05-11 01:06:44 | ![]() |
v2.1.0 | e51aff2 | 2020-02-10 01:00:37 | ![]() |
v2.0.2 | a00ba75 | 2019-10-09 23:11:32 | ![]() |
v2.0.1 | dc8210d | 2019-07-01 08:30:51 | ![]() |
v2.0.0 | b1f632d | 2019-05-02 16:59:38 | ![]() |
v1.4.1 | dea7ba0 | 2019-01-01 19:18:42 | Rafael Barros |
v1.4.0 | 3e004d9 | 2018-09-14 01:58:48 | ![]() |
v1.3.0 | eb62256 | 2018-05-11 11:14:18 | ![]() |
v1.2.0 | 6d634ca | 2017-12-01 17:52:15 | ![]() |
v1.1.0 | 1ec2661 | 2017-08-19 14:37:15 | ![]() |
名称 | Rev. | 时间 | 作者 | Message |
---|---|---|---|---|
master | a34c81e | 2023-03-20 10:17:28 | ChantXu64 | This closes #1448, speed ... |
v2 | a34c81e | 2023-03-20 10:17:28 | ChantXu64 | This closes #1448, speed ... |
formula | eee6607 | 2022-06-29 00:18:48 | ![]() |
ref #65, new formula functi... |
Excelize 是 Go 语言编写的用于操作 Office Excel 文档基础库,基于 ECMA-376,ISO/IEC 29500 国际标准。可以使用它来读取、写入由 Microsoft Excel™ 2007 及以上版本创建的电子表格文档。支持 XLAM / XLSM / XLSX / XLTM / XLTX 等多种文档格式,高度兼容带有样式、图片(表)、透视表、切片器等复杂组件的文档,并提供流式读写函数,用于处理包含大规模数据的工作簿。可应用于各类报表平台、云计算、边缘计算等系统。使用本类库要求使用的 Go 语言为 1.16 或更高版本,完整的使用文档请访问 go.dev 或查看 参考文档。
go get github.com/xuri/excelize
go get github.com/xuri/excelize/v2
下面是一个创建 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 文档的例子:
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()
}
}
使用 Excelize 生成图表十分简单,仅需几行代码。您可以根据工作表中的已有数据构建图表,或向工作表中添加数据并创建图表。
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: "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.ChartTitle{
Name: "Fruit 3D Clustered Column Chart",
},
}); err != nil {
fmt.Println(err)
return
}
// 根据指定路径保存文件
if err := f.SaveAs("Book1.xlsx"); err != nil {
fmt.Println(err)
}
}
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 创作共用授权条款。