Golang中读写CSV文件的全面指南_golang csv,10天拿到腾讯Golang岗offer

先自我介绍一下,小编浙江大学毕业,去过华为、字节跳动等大厂,目前阿里P7

深知大多数程序员,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年最新Golang全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友。
img
img
img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上Go语言开发知识点,真正体系化!

由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新

如果你需要这些资料,可以添加V获取:vip1024b (备注go)
img

正文

  1. 创建结构体:使用结构体定义CSV文件中的记录结构。

type Person struct {
Name string csv:"name"
Age int csv:"age"
Gender string csv:"gender"
}

在上面的示例中,我们定义了一个名为Person的结构体,其中的字段使用csv标签指定了他们在CSV文件中对应的列名。
4. 读取CSV文件:使用gocsv.UnmarshalFile函数从CSV文件中读取记录。

file, err := os.OpenFile(“data.csv”, os.O_RDWR|os.O_CREATE, os.ModePerm)
if err != nil {
fmt.Println(“打开文件失败:”, err)
return
}
defer file.Close()

var people []*Person
if err := gocsv.UnmarshalFile(file, &people); err != nil {
fmt.Println(“读取文件失败:”, err)
return
}

在上述代码中,我们使用os.OpenFile函数打开一个名为data.csv的文件,并将其传递给gocsv.UnmarshalFile函数来读取CSV记录。通过传递一个指向记录切片的指针,我们可以将文件中的记录存储在people变量中。
5. 写入CSV文件:使用gocsv.MarshalFile函数将记录写入CSV文件。

file, err := os.OpenFile(“output.csv”, os.O_RDWR|os.O_CREATE, os.ModePerm)
if err != nil {
fmt.Println(“创建文件失败:”, err)
return
}
defer file.Close()

people := []*Person{
{Name: “Alice”, Age: 21, Gender: “F”},
{Name: “Bob”, Age: 25, Gender: “M”},
}
if err := gocsv.MarshalFile(&people, file); err != nil {
fmt.Println(“写入文件失败:”, err)
return
}

在上述代码中,我们使用os.OpenFile函数创建一个名为output.csv的文件,并将其传递给gocsv.MarshalFile函数来写入CSV记录。通过传递一个记录切片的指针,我们可以将记录写入文件中。

Gocarina/gocsv还提供了其他一些方便的功能,例如选择性解析、自定义类型映射、标记解析等,使CSV文件的处理更加灵活和便捷。

2. GoCSV

GoCSV是另一个流行的CSV处理库,提供了丰富的功能和灵活性。它具有以下特点:

  • 支持读取和写入CSV文件:GoCSV提供了直观且易于使用的API来读取和写入CSV文件。
  • 提供行级别的操作:可以对每行数据进行操作,例如过滤、更新、删除等。
  • 支持自定义解析器和写入器:允许您创建自定义的解析器和写入器,以符合特定的需求。

要使用GoCSV库,您需要按照以下步骤进行设置:

  1. 安装GoCSV库:在终端中执行以下命令安装GoCSV库。

go get github.com/gocarina/gocsv

  1. 导入所需的包:在代码中导入github.com/gocarina/gocsv和其他所需的包。

import (
“github.com/gocarina/gocsv”
“os”
)

  1. 创建结构体:使用结构体定义CSV文件中的记录结构。

type Person struct {
Name string csv:"name"
Age int csv:"age"
Gender string csv:"gender"
}

在上面的示例中,我们定义了一个名为Person的结构体,其中的字段使用csv标签指定了他们在CSV文件中对应的列名。
4. 读取CSV文件:使用gocsv.UnmarshalFile函数从CSV文件中读取记录。

file, err := os.OpenFile(“data.csv”, os.O_RDWR|os.O_CREATE, os.ModePerm)
if err != nil {
fmt.Println(“打开文件失败:”, err)
return
}
defer file.Close()

var people []*Person
if err := gocsv.UnmarshalFile(file, &people); err != nil {
fmt.Println(“读取文件失败:”, err)
return
}

在上述代码中,我们使用os.OpenFile函数打开一个名为data.csv的文件,并将其传递给gocsv.UnmarshalFile函数来读取CSV记录。通过传递一个指向记录切片的指针,我们可以将文件中的记录存储在people变量中。
5. 写入CSV文件:使用gocsv.MarshalFile函数将记录写入CSV文件。

file, err := os.OpenFile(“output.csv”, os.O_RDWR|os.O_CREATE, os.ModePerm)
if err != nil {
fmt.Println(“创建文件失败:”, err)
return
}
defer file.Close()

people := []*Person{
{Name: “Alice”, Age: 21, Gender: “F”},
{Name: “Bob”, Age: 25, Gender: “M”},
}
if err := gocsv.MarshalFile(&people, file); err != nil {
fmt.Println(“写入文件失败:”, err)
return
}

在上述代码中,我们使用os.OpenFile函数创建一个名为output.csv的文件,并将其传递给gocsv.MarshalFile函数来写入CSV记录。通过传递一个记录切片的指针,我们可以将记录写入文件中。

GoCSV还提供了其他一些方便的功能,如行级操作、自定义解析器和写入器等,使CSV文件的处理更加灵活和强大。

案例

下面我将给您提供 3 个使用 Gocarina/gocsv 库和 GoCSV 库处理 CSV 文件的案例。

案例1:读取和打印 CSV 文件中的记录

下面是一个使用 Gocarina/gocsv 库读取 data.csv 文件,并打印出每一条记录的示例:

package main

import (
“encoding/csv”
“fmt”
“os”

“github.com/Gocarina/gocsv”
)

type Person struct {
Name string csv:"name"
Age int csv:"age"
Gender string csv:"gender"
}

func main() {
file, err := os.OpenFile(“data.csv”, os.O_RDWR|os.O_CREATE, os.ModePerm)
if err != nil {
fmt.Println(“打开文件失败:”, err)
return
}
defer file.Close()

var people []*Person
if err := gocsv.UnmarshalFile(file, &people); err != nil {
fmt.Println(“读取文件失败:”, err)
return
}

for _, p := range people {
fmt.Println(“Name:”, p.Name)
fmt.Println(“Age:”, p.Age)
fmt.Println(“Gender:”, p.Gender)
fmt.Println(“--------”)
}
}

案例2:将结构体切片写入 CSV 文件

下面是一个使用 Gocarina/gocsv 库将结构体切片写入 output.csv 文件的示例:

package main

import (
“encoding/csv”
“fmt”
“os”

“github.com/Gocarina/gocsv”
)

type Person struct {
Name string csv:"name"
Age int csv:"age"
Gender string csv:"gender"
}

func main() {
file, err := os.OpenFile(“output.csv”, os.O_RDWR|os.O_CREATE, os.ModePerm)
if err != nil {
fmt.Println(“创建文件失败:”, err)
return
}
defer file.Close()

people := []*Person{
{Name: “Alice”, Age: 21, Gender: “F”},
{Name: “Bob”, Age: 25, Gender: “M”},
}
if err := gocsv.MarshalFile(&people, file); err != nil {
fmt.Println(“写入文件失败:”, err)
return
}
fmt.Println(“写入成功!”)
}

案例3:使用 GoCSV 库进行行级操作

下面是一个使用 GoCSV 库进行行级操作的示例,将具有特定条件的记录写入 filtered.csv 文件中:

package main

import (
“encoding/csv”
“fmt”
“os”

“github.com/gocarina/gocsv”
)

type Person struct {

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化的资料的朋友,可以添加V获取:vip1024b (备注Go)
img

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
na/gocsv"
)

type Person struct {

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化的资料的朋友,可以添加V获取:vip1024b (备注Go)
[外链图片转存中…(img-MNhqPu4D-1713130750911)]

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

  • 28
    点赞
  • 27
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值