Go语言通过encoding/csv包实现CSV文件读写,支持从文件读取、逐行解析、写入数据及处理特殊字符。首先使用csv.NewReader读取文件内容,可选择跳过表头或逐行处理大文件以节省内存;接着通过csv.NewWriter将二维字符串切片写入文件,并调用Flush确保数据落盘;该库自动处理含逗号、换行符的字段,无需第三方依赖,只需注意错误处理与资源释放即可高效完成CSV操作。

Go语言通过标准库encoding/csv提供了对CSV文件的读写支持,使用简单且高效。下面通过几个常见场景展示如何用Golang处理CSV文件。
使用csv.NewReader从文件或字符串中读取数据:
package main
import (
"encoding/csv"
"os"
"fmt"
)
func main() {
file, err := os.Open("data.csv")
if err != nil {
panic(err)
}
defer file.Close()
reader := csv.NewReader(file)
records, err := reader.ReadAll()
if err != nil {
panic(err)
}
for _, record := range records {
fmt.Println(record) // 每一行是一个[]string
}
}
如果CSV第一行是表头,可以跳过:records = records[1:]
对于较大的CSV文件,避免一次性加载到内存,应逐行处理:
reader := csv.NewReader(file)
for {
record, err := reader.Read()
if err == io.EOF {
break
}
if err != nil {
panic(err)
}
fmt.Println(record)
}
使用csv.NewWriter将数据写入文件或缓冲区:
立即学习“go语言免费学习笔记(深入)”;
示例:写入结构化数据
package main
import (
"encoding/csv"
"os"
)
func main() {
data := [][]string{
{"Name", "Age", "City"},
{"Alice", "25", "Beijing"},
{"Bob", "30", "Shanghai"},
}
file, err := os.Create("output.csv")
if err != nil {
panic(err)
}
defer file.Close()
writer := csv.NewWriter(file)
defer writer.Flush()
for _, row := range data {
err := writer.Write(row)
if err != nil {
panic(err)
}
}
}
writer.Flush()必须调用,确保所有数据写入磁盘。
CSV标准允许字段中包含逗号、换行符或引号,encoding/csv会自动处理:
data := [][]string{
{"User", "Comment"},
{"Tom", "Great product, love it!"},
{"Jane", "Issue:\nFile not found."},
}
写入时,含有逗号或换行的字段会自动加引号,如:
"Issue:<br>File not found."
基本上就这些。Go的encoding/csv开箱即用,适合大多数CSV处理需求,无需引入第三方库。注意错误处理和资源释放即可。不复杂但容易忽略。
以上就是Golang encoding/csv处理CSV文件示例的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号