golang-读写csv文件

文章介绍了如何使用Go语言的encoding/csv库有效地读取和处理大型CSV文件,包括打开文件、设置分隔符以及追加写入数据的操作示例。
摘要由CSDN通过智能技术生成

        读写csv文件的方式很多,对于csv文件比较大的,比较有效的读写方式是使用"encoding/csv"库。代码如下:

package main

import (
	"encoding/csv"
	"fmt"
	"io"
	"log"
	"os"
)

func main() {

	// 打开文件
	file, err := os.Open("large_file.csv")
	if err != nil {
		panic(err)
	}
	defer func(file *os.File) {
		err := file.Close()
		if err != nil {
			log.Fatal("文件关闭失败", err)
		}
	}(file)

	// 创建CSV读取器
	reader := csv.NewReader(file)
	reader.Comma = ',' // 默认使用逗号作为分割符,也可以自定义分隔符
	// 读取CSV文件
	for {
		record, err := reader.Read()
		if err == io.EOF {
			break
		} else if err != nil {
			panic(err)
		}
		// 处理record
		fmt.Println(record)
        // 打印第一个字段
        fmt.Println(record[0])
	}
}

        如果要追加写入,则使用以下程序段:

package main

import (
	"encoding/csv"
	"log"
	"os"
)

func main() {
	// 如果没有文件,则新建文件,然后追加写入,如果写入的文件存在,则追加
	file, err := os.OpenFile("large_file.csv", os.O_APPEND|os.O_CREATE|os.O_WRONLY, 0644)
	if err != nil {
		log.Fatal(err)
	}
	defer file.Close()

	writer := csv.NewWriter(file)
	defer writer.Flush()

	// 写入CSV文件
	for _, record := range [][]string{
		{"1", "Alice", "30"},
		{"2", "Donshu", "50"},
		// ...
	} {
		err := writer.Write(record)
		if err != nil {
			panic(err)
		}
	}
}

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值