fmt.Println(“写入文件失败:”, err)
return
}
在上述代码中,我们使用os.OpenFile
函数创建一个名为output.csv
的文件,并将其传递给gocsv.MarshalFile
函数来写入CSV记录。通过传递一个记录切片的指针,我们可以将记录写入文件中。
Gocarina/gocsv
还提供了其他一些方便的功能,例如选择性解析、自定义类型映射、标记解析等,使CSV文件的处理更加灵活和便捷。
2. GoCSV
GoCSV
是另一个流行的CSV处理库,提供了丰富的功能和灵活性。它具有以下特点:
- 支持读取和写入CSV文件:
GoCSV
提供了直观且易于使用的API来读取和写入CSV文件。 - 提供行级别的操作:可以对每行数据进行操作,例如过滤、更新、删除等。
- 支持自定义解析器和写入器:允许您创建自定义的解析器和写入器,以符合特定的需求。
要使用GoCSV
库,您需要按照以下步骤进行设置:
- 安装
GoCSV
库:在终端中执行以下命令安装GoCSV
库。
go get github.com/gocarina/gocsv
- 导入所需的包:在代码中导入
github.com/gocarina/gocsv
和其他所需的包。
import (
“github.com/gocarina/gocsv”
“os”
)
- 创建结构体:使用结构体定义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 {
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
}
filteredPeople := make([]*Person, 0)
for _, p := range people {
if p.Age >= 18 && p.Gender == “F” {
filteredPeople = append(filteredPeople, p)
}
}
filteredFile, err := os.OpenFile(“filtered.csv”, os.O_RDWR|os.O_CREATE, os.ModePerm)
if err != nil {
fmt.Println(“创建文件失败:”, err)
return
}
defer filteredFile.Close()
if err := gocsv.MarshalFile(&filteredPeople, filteredFile); err != nil {
fmt.Println(“写入文件失败:”, err)
return
}
fmt.Println(“写入成功!”)
}
这些案例涵盖了使用 Gocarina/gocsv
库和 GoCSV
库进行 CSV 文件处理的常见场景。您可以根据自己的需求进行相应的调整和修改。希望对您有所帮助!
三、总结
CSV文件是一种常见的数据存储格式,在许多场景下被广泛使用。在Golang中,我们可以使用标准库以及一些第三方库来读取和写入CSV文件。标准库encoding/csv
提供了简单而高效的API来处理CSV文件,而第三方库如Gocarina/gocsv
和GoCSV
提供了更多的功能和灵活性,使CSV文件的处理更加便捷和强大。
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数Go语言工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年Go语言全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Golang知识点,真正体系化!
由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新
如果你觉得这些内容对你有帮助,可以添加V获取:vip1024b (备注Go)
一个人可以走的很快,但一群人才能走的更远。不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎扫码加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
lang知识点,真正体系化!**
由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新
如果你觉得这些内容对你有帮助,可以添加V获取:vip1024b (备注Go)
[外链图片转存中…(img-KwBd2Tvx-1712966380746)]
一个人可以走的很快,但一群人才能走的更远。不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎扫码加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!