Go语言通过encoding/csv包可高效读取CSV文件,结合os.Open打开文件并用csv.NewReader逐行或批量读取数据,适用于处理大小文件及含标题的表格数据。

在Go语言中读取CSV文件非常简单,主要依赖标准库中的 encoding/csv 包。结合 os 和 io 包,可以轻松实现从文件中读取结构化数据。
导入必要包
读取CSV文件需要以下包:
import ( "encoding/csv" "os" "fmt")
打开并读取CSV文件
使用 os.Open 打开文件,然后用 csv.NewReader 创建一个读取器:
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("读取文件失败:", err) return}// 遍历每一行数据for _, record := range records { fmt.Println(record) // 每一行是一个字符串切片}
逐行读取处理大文件
如果CSV文件较大,不建议使用 ReadAll 一次性加载。可以使用 Read 方法逐行读取,节省内存:
立即学习“go语言免费学习笔记(深入)”;
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(如表格数据)
很多CSV文件第一行是列名。你可以先读取标题,再处理后续数据:
header, err := reader.Read()if err != nil { fmt.Println("读取标题失败:", err) return}fmt.Println("字段名:", header)for { row, err := reader.Read() if err == io.EOF { break } if err != nil { fmt.Println("读取数据行失败:", err) return } // 假设前三列分别是姓名、年龄、邮箱 name := row[0] age := row[1] email := row[2] fmt.Printf("姓名: %s, 年龄: %s, 邮箱: %sn", name, age, email)}
基本上就这些。Golang的CSV读取功能简洁高效,适合处理各种表格型数据文件。注意检查错误并及时关闭文件即可。
以上就是Golang如何读取CSV文件数据的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1412641.html
微信扫一扫
支付宝扫一扫