2024年最全Golang中读写CSV文件的全面指南_golang csv,阿里快手拼多多等7家大厂Golang面试真题

img
img

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

需要这份系统化的资料的朋友,可以添加戳这里获取

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

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

record := []string{“Alice”, “21”, “F”}
err = writer.Write(record)
if err != nil {
fmt.Println(“写入记录失败:”, err)
return
}


在上述代码中,我们使用`os.Create()`函数创建一个名为`output.csv`的文件,并将其传递给`csv.NewWriter()`函数创建一个CSV Writer对象。类似于读取CSV文件时,我们需要在写入结束时关闭文件和刷新缓冲区,以确保数据被正确写入。


### 二、使用第三方库处理CSV文件


除了标准库之外,还有许多第三方库可以在Golang中处理CSV文件。这些库通常提供更多功能和灵活性,使CSV文件的处理更加高效和方便。下面介绍两个受欢迎的第三方库:


#### 1. Gocarina/gocsv


`Gocarina/gocsv`是一个功能强大的CSV处理库,提供了读取、写入和转换CSV文件的能力。它具有以下特点:


* 支持高级功能:包括自定义类型映射、标记解析、选择性解析等。
* 具有更好的性能:相对于标准库,`Gocarina/gocsv`提供了更好的性能和效率。
* 简单易用:提供了一组简洁明了的API,使CSV文件的处理变得简单易用。


要使用`Gocarina/gocsv`库,您需要按照以下步骤进行设置:


1. 安装`Gocarina/gocsv`库:在终端中执行以下命令安装`Gocarina/gocsv`库。

 

go get github.com/Gocarina/gocsv

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

 

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

3. 创建结构体:使用结构体定义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

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

 

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

3. 创建结构体:使用结构体定义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”

img
img

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

需要这份系统化的资料的朋友,可以添加戳这里获取

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

9)]
[外链图片转存中…(img-rBQsYEcC-1715399949419)]

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

需要这份系统化的资料的朋友,可以添加戳这里获取

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

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值