Go语言通过encoding/csv包可高效读取解析CSV文件。使用os.Open打开文件后,结合csv.NewReader逐行读取,适合大文件的流式处理;通过ReadAll()加载全部数据,适用于小文件。可将每行数据按索引映射到结构体字段,实现结构化存储。包原生支持处理含引号、逗号等特殊字符的字段,但需确保文件为UTF-8编码。正确处理错误和内存使用是关键。

在Go语言中读取和解析CSV文件非常简单,得益于标准库
encoding/csv
os
bufio
使用
os.Open
csv.NewReader
package main
import (
"encoding/csv"
"fmt"
"os"
)
func main() {
file, err := os.Open("data.csv")
if err != nil {
fmt.Println("打开文件失败:", err)
return
}
defer file.Close()
reader := csv.NewReader(file)
records, err := reader.ReadAll()
if err != nil {
fmt.Println("读取CSV失败:", err)
return
}
for _, record := range records {
fmt.Println(record)
}
}
这段代码会将CSV每行解析为字符串切片。假设
data.csv
姓名,年龄,城市 张三,25,北京 李四,30,上海
输出结果为:
立即学习“go语言免费学习笔记(深入)”;
[姓名 年龄 城市] [张三 25 北京] [李四 30 上海]
对于较大的CSV文件,不建议使用
ReadAll()
Read()
reader := csv.NewReader(file)
for {
record, err := reader.Read()
if err == io.EOF {
break
}
if err != nil {
fmt.Println("读取行出错:", err)
return
}
fmt.Println(record)
}
这种方式适合处理上万行的数据,避免内存溢出。
实际开发中,通常需要把每行数据解析为结构体。虽然
csv.Reader
type Person struct {
Name string
Age int
City string
}
var people []Person
records, _ := reader.ReadAll()
for i, record := range records {
if i == 0 {
continue // 跳过表头
}
age, _ := strconv.Atoi(record[1])
people = append(people, Person{
Name: record[0],
Age: age,
City: record[2],
})
}
fmt.Println(people)
这样就能把CSV数据转换为结构化对象,便于后续处理或JSON输出。
CSV标准支持字段中包含逗号、换行或引号,
encoding/csv
例如这一行:
"张,三","25,5","北京"
会被正确解析为三个字段:
张,三
25,5
北京
如果源数据编码不是UTF-8(如GBK),需先转码,Go标准库不支持自动识别非UTF-8编码。
基本上就这些。Golang处理CSV足够简洁,对大多数场景都够用。注意错误处理和内存使用,尤其是大文件场景。不复杂但容易忽略细节。
以上就是Golang读取CSV文件与解析示例的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号