Golang中读写CSV文件的全面指南_golang csv

  1. 安装Gocarina/gocsv库:在终端中执行以下命令安装Gocarina/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记录。通过传递一个记录切片的指针,我们可以将记录写入文件中。

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 {
    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 {
  • 3
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值