首页 > 后端开发 > Golang > 正文

Golangencoding/csv读取与写入CSV文件示例

P粉602998670
发布: 2025-09-13 09:36:01
原创
392人浏览过
Go语言通过encoding/csv包高效处理CSV文件读写。首先使用os.Open打开文件,结合csv.NewReader读取数据,可调用ReadAll()一次性读取或Read()逐行读取以节省内存;写入时用os.Create创建文件,csv.NewWriter写入数据,需注意调用Flush()确保数据落盘;支持自定义分隔符,如设置Comma=';'处理分号分隔文件,适用于欧洲格式CSV,广泛用于配置、报表等场景。

golangencoding/csv读取与写入csv文件示例

Go语言通过标准库

encoding/csv
登录后复制
提供了对CSV文件的读取和写入支持,使用简单且高效。下面通过具体示例展示如何用Golang处理CSV文件。

读取CSV文件

使用

csv.NewReader
登录后复制
可以从文件或任意
io.Reader
登录后复制
中读取CSV数据。通常配合
os.Open
登录后复制
打开本地文件。

示例:读取一个名为

data.csv
登录后复制
的文件内容:

// 导入必要包
import (
    "encoding/csv"
    "os"
    "fmt"
)

// 打开CSV文件
file, err := os.Open("data.csv")
if err != nil {
    log.Fatal(err)
}
defer file.Close()

// 创建csv reader
reader := csv.NewReader(file)

// 读取所有记录
records, err := reader.ReadAll()
if err != nil {
    log.Fatal(err)
}

// 遍历输出每行
for _, record := range records {
    fmt.Println(record)
}

如果想逐行读取以节省内存(适合大文件),可使用

Read()
登录后复制
方法:

立即学习go语言免费学习笔记(深入)”;

record, err := reader.Read()
for err == nil {
    fmt.Println(record)
    record, err = reader.Read()
}

写入CSV文件

使用

csv.NewWriter
登录后复制
可以将数据写入文件或任何
io.Writer
登录后复制
目标。

示例:创建并写入

output.csv
登录后复制
文件:

小绿鲸英文文献阅读器
小绿鲸英文文献阅读器

英文文献阅读器,专注提高SCI阅读效率

小绿鲸英文文献阅读器 199
查看详情 小绿鲸英文文献阅读器
// 创建或清空文件
file, err := os.Create("output.csv")
if err != nil {
    log.Fatal(err)
}
defer file.Close()

// 创建csv writer
writer := csv.NewWriter(file)
defer writer.Flush() // 确保数据写入磁盘

// 要写入的数据
data := [][]string{
    {"Name", "Age", "City"},
    {"Alice", "25", "Beijing"},
    {"Bob", "30", "Shanghai"},
}

// 逐行写入
for _, row := range data {
    err := writer.Write(row)
    if err != nil {
        log.Fatal(err)
    }
}

注意:调用

writer.Flush()
登录后复制
非常重要,否则缓冲区中的数据不会真正写入文件。

自定义分隔符

默认情况下,

csv.Reader
登录后复制
csv.Writer
登录后复制
使用逗号作为字段分隔符。若需使用其他字符(如分号或制表符),可手动设置。

例如,处理以分号分隔的CSV:

reader := csv.NewReader(file)
reader.Comma = ';'

writer := csv.NewWriter(file)
writer.Comma = ';'

常见场景包括欧洲格式CSV常使用

;
登录后复制
避免与小数点
,
登录后复制
冲突。

基本上就这些。利用

encoding/csv
登录后复制
包,Golang能轻松完成结构化文本数据的导入导出,适合配置、报表或数据迁移等任务。

以上就是Golangencoding/csv读取与写入CSV文件示例的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号