golang 写入 xls

发布时间:2024-12-22 22:27:19

在Golang中,我们可以使用第三方库来将数据写入Excel表格文件(xls)。本文将介绍如何使用golang写入xls文件,并提供了一些实际应用案例。

安装第三方库

在写入xls文件之前,我们需要先安装一个可用的第三方库,例如"xlsx"。

创建工作簿和工作表

首先,我们需要创建一个工作簿对象,用于存储数据并生成Excel文件。通过导入"xlsx"包,我们可以轻松创建一个新的工作簿:

file := xlsx.NewFile()

然后,我们可以在工作簿中创建工作表对象:

sheet, err := file.AddSheet("Sheet1")
if err != nil {
    // 错误处理...
}

写入数据

一旦创建了工作表,我们就可以开始向其中写入数据。假设我们想要将一些字符串和数字值写入第一行和第一列,我们可以使用以下代码:

cell := sheet.Cell(0, 0)
cell.Value = "Hello"
cell = sheet.Cell(0, 1)
cell.Value = "World"

cell = sheet.Cell(1, 0)
cell.SetInt(42)
cell = sheet.Cell(1, 1)
cell.SetInt(100)

保存文件

一旦我们完成了对工作簿的写操作,我们可以将其保存到文件中:

err = file.Save("output.xlsx")
if err != nil {
    // 错误处理...
}

实际应用案例

下面是一个实际的应用案例,演示了如何将从数据库中获取的数据写入Excel文件:

func main() {
    db, err := sql.Open("mysql", "user:password@tcp(127.0.0.1:3306)/database")
    if err != nil {
        log.Fatal(err)
    }
    defer db.Close()

    rows, err := db.Query("SELECT * FROM users")
    if err != nil {
        log.Fatal(err)
    }
    defer rows.Close()

    file := xlsx.NewFile()
    sheet, err := file.AddSheet("Users")
    if err != nil {
        log.Fatal(err)
    }
    defer file.Save("users.xlsx")

    var (
        id   int
        name string
        age  int
    )

    row := sheet.AddRow()
    cell := row.AddCell()
    cell.Value = "ID"
    cell = row.AddCell()
    cell.Value = "Name"
    cell = row.AddCell()
    cell.Value = "Age"

    for rows.Next() {
        err := rows.Scan(&id, &name, &age)
        if err != nil {
            log.Fatal(err)
        }

        row := sheet.AddRow()
        cell := row.AddCell()
        cell.SetInt(id)
        cell = row.AddCell()
        cell.SetValue(name)
        cell = row.AddCell()
        cell.SetInt(age)
    }

    err = rows.Err()
    if err != nil {
        log.Fatal(err)
    }
}

以上就是使用golang将数据写入xls文件的基本步骤和实际应用案例。通过掌握这些内容,我们可以在golang中轻松地处理Excel文件,并实现各种自定义的需求。

相关推荐