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

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文件
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库会自动处理包含逗号、换行或引号的字段。只要使用Write或WriteAll,内部会正确添加引号并转义。
例如:
{"张三", "28", "深圳,南山区"}会被写成:
张三,28,"深圳,南山区"读取时也能正确解析为三个字段。
逐行读取大文件
对于大CSV文件,不建议使用ReadAll()一次性加载全部内容,应使用Read()逐行处理以节省内存。
基本上就这些。Golang操作CSV非常直接,结合os和csv包就能完成大多数任务。注意及时关闭文件和调用writer.Flush(),避免数据丢失。










