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

Golang如何操作CSV文件_Golang CSV读取与写入示例

P粉602998670
发布: 2025-12-01 06:51:42
原创
184人浏览过
Go语言通过encoding/csv包实现CSV读写,先使用os.Open打开文件并用csv.NewReader读取数据,可调用ReadAll一次性读取或Read逐行解析;写入时用os.Create创建文件,csv.NewWriter写入数据,需调用Flush确保数据落盘;库自动处理含逗号、引号的字段;大文件应逐行读取以节省内存。

golang如何操作csv文件_golang csv读取与写入示例

Go语言通过标准库encoding/csv提供了对CSV文件的读取和写入支持,使用简单且高效。下面介绍如何用Golang读取和写入CSV文件,并附上实用示例。

读取CSV文件

使用csv.NewReader()可以从文件或字符串中读取CSV数据。通常配合os.Open打开文件,然后逐行读取记录。

示例:从文件读取CSV内容

// main.go package main import ( "encoding/csv" "fmt" "log" "os" ) func readCSV(filename string) { file, err := os.Open(filename) if err != nil { log.Fatal("无法打开文件:", err) } defer file.Close() reader := csv.NewReader(file) records, err := reader.ReadAll() if err != nil { log.Fatal("读取CSV失败:", err) } for _, record := range records { fmt.Println(record) // 每一行是一个[]string } } func main() { readCSV("data.csv") }

假设data.csv内容如下:

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

姓名,年龄,城市 Alice,25,北京 Bob,30,上海

运行程序将输出:

[姓名 年龄 城市] [Alice 25 北京] [Bob 30 上海]

写入CSV文件

使用csv.NewWriter()可以将数据写入文件或任何实现了io.Writer接口的对象。

示例:写入CSV文件

Riffusion
Riffusion

AI生成不同风格的音乐

Riffusion 87
查看详情 Riffusion
package main import ( "encoding/csv" "log" "os" ) func writeCSV(filename string) { file, err := os.Create(filename) if err != nil { log.Fatal("创建文件失败:", err) } defer file.Close() writer := csv.NewWriter(file) defer writer.Flush() // 确保所有数据写入磁盘 // 写入表头 header := []string{"姓名", "年龄", "城市"} if err := writer.Write(header); err != nil { log.Fatal("写入表头失败:", err) } // 写入多行数据 data := [][]string{ {"Alice", "25", "北京"}, {"Bob", "30", "上海"}, {"Charlie", "35", "广州"}, } if err := writer.WriteAll(data); err != nil { log.Fatal("写入数据失败:", err) } } func main() { writeCSV("output.csv") }

执行后会生成output.csv,内容与前面示例一致。

处理带引号或特殊字符的数据

CSV库会自动处理包含逗号、换行或引号的字段。只要使用WriteWriteAll,内部会正确添加引号并转义。

例如:

{"张三", "28", "深圳,南山区"}

会被写成:

张三,28,"深圳,南山区"

读取时也能正确解析为三个字段。

逐行读取大文件

对于大CSV文件,不建议使用ReadAll()一次性加载全部内容,应使用Read()逐行处理以节省内存。

func readCSVLineByLine(filename string) { file, err := os.Open(filename) if err != nil { log.Fatal(err) } defer file.Close() reader := csv.NewReader(file) for { record, err := reader.Read() if err == io.EOF { break } if err != nil { log.Fatal("读取行失败:", err) } fmt.Println(record) } }

基本上就这些。Golang操作CSV非常直接,结合oscsv包就能完成大多数任务。注意及时关闭文件和调用writer.Flush(),避免数据丢失

以上就是Golang如何操作CSV文件_Golang 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号