
在 go 语言中处理 excel 文件,通常需要借助第三方库。github.com/tealeg/xlsx 是一个功能强大且广泛使用的库,它提供了读取和写入 .xlsx 格式 excel 文件的能力。该库封装了底层的文件解析逻辑,使得开发者能够以结构化的方式访问 excel 文件中的数据,如工作表、行和单元格。
在使用 xlsx 包之前,需要将其安装到 Go 项目中。打开终端或命令行工具,执行以下 go get 命令:
go get -v github.com/tealeg/xlsx
此命令会自动下载 xlsx 包及其所有依赖项,并将其安装到 Go 模块缓存中,以便在项目中引用。
使用 xlsx 包读取 Excel 文件的基本步骤包括:
以下是一个完整的 Go 语言程序示例,演示了如何打开一个 Excel 文件,并打印出其中所有工作表、行和单元格的内容。
首先,请确保在运行此代码之前,在程序同一目录下创建一个名为 example.xlsx 的 Excel 文件,并填充一些数据,例如:
example.xlsx 内容示例:
Sheet1: | 姓名 | 年龄 | 城市 | | :--- | :--- | :--- | | 张三 | 30 | 北京 | | 李四 | 25 | 上海 |
Sheet2: | 产品 | 价格 | 数量 | | :--- | :--- | :--- | | 铅笔 | 2.5 | 100 | | 笔记本 | 15.0 | 50 |
Go 程序代码:
package main
import (
"fmt"
"log"
"github.com/tealeg/xlsx" // 导入 xlsx 包
)
func main() {
// 指定要读取的 Excel 文件路径
// 确保此文件存在于与Go程序相同的目录下或提供完整路径
filePath := "example.xlsx"
// 1. 打开 Excel 文件
// xlsx.OpenFile 返回一个 *File 对象和可能的错误
xlFile, err := xlsx.OpenFile(filePath)
if err != nil {
// 如果打开文件失败,使用 log.Fatalf 打印错误并退出程序
log.Fatalf("打开Excel文件失败: %v", err)
}
fmt.Printf("成功打开文件: %s\n\n", filePath)
// 2. 遍历文件中的所有工作表
// xlFile.Sheets 是一个 *Sheet 类型的切片
for _, sheet := range xlFile.Sheets {
fmt.Printf("--- 工作表: %s ---\n", sheet.Name)
// 3. 遍历当前工作表中的所有行
// sheet.Rows 是一个 *Row 类型的切片
for rowIndex, row := range sheet.Rows {
// 过滤掉可能存在的空行(如果需要)
if row == nil {
continue
}
// 打印当前行号(rowIndex 从 0 开始,所以加 1)
fmt.Printf(" 行 %d: ", rowIndex+1)
// 4. 遍历当前行中的所有单元格
// row.Cells 是一个 *Cell 类型的切片
for colIndex, cell := range row.Cells {
// 5. 获取单元格的字符串值
// cell.String() 方法返回单元格内容的字符串表示
text := cell.String()
fmt.Printf("列 %d: %s | ", colIndex+1, text)
}
fmt.Println() // 每一行结束后换行
}
fmt.Println() // 每个工作表结束后空一行,提高可读性
}
}
运行结果示例:
成功打开文件: example.xlsx --- 工作表: Sheet1 --- 行 1: 列 1: 姓名 | 列 2: 年龄 | 列 3: 城市 | 行 2: 列 1: 张三 | 列 2: 30 | 列 3: 北京 | 行 3: 列 1: 李四 | 列 2: 25 | 列 3: 上海 | --- 工作表: Sheet2 --- 行 1: 列 1: 产品 | 列 2: 价格 | 列 3: 数量 | 行 2: 列 1: 铅笔 | 列 2: 2.5 | 列 3: 100 | 行 3: 列 1: 笔记本 | 列 2: 15 | 列 3: 50 |
通过 github.com/tealeg/xlsx 包,Go 语言开发者可以方便高效地读取 Excel 文件中的数据。本教程从包的安装开始,详细介绍了打开文件、遍历工作表、行和单元格的完整流程,并提供了一个实用的代码示例。遵循本教程的指导和最佳实践,您将能够轻松地在 Go 应用程序中集成 Excel 文件处理功能。
以上就是Go 语言中读取 Excel 文件指南的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号