新闻中心

如何使用Golang encoding/csv处理CSV文件_Golang CSV文件读写示例

2025-12-16
浏览次数:
返回列表
Go语言中encoding/csv包用于读写CSV文件,支持标准及自定义分隔符的解析与生成,能自动处理带引号字段。1. 使用csv.NewReader读取文件或字符串数据,可调用ReadAll()一次性读取或循环Read()逐行读取;2. 使用csv.NewWriter写入数据到文件或缓冲区,需调用Flush()确保数据写入;3. 支持自定义分隔符,如制表符或分号,通过设置Comma字段实现;4. 自动处理含逗号、换行等特殊字符的字段,无需手动解析引号内容。示例涵盖打开文件、创建读写器、遍历记录、错误处理及资源释放全过程,适用于报表导出、配置导入等场景。

如何使用golang encoding/csv处理csv文件_golang csv文件读写示例

在Go语言中,encoding/csv 包提供了对CSV(逗号分隔值)文件的读写支持。它属于标准库,无需额外安装,适合处理结构化数据,比如导出报表、导入配置或解析日志。下面通过具体示例说明如何使用它进行CSV文件的读取与写入。

读取CSV文件

使用 csv.NewReader 可以从任何实现了 io.Reader 接口的对象中读取数据,常见的是从文件或字符串中读取。

以下是从本地CSV文件读取所有记录的示例:

package main

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

func main() {
    // 打开CSV文件
    file, err := os.Open("data.csv")
    if err != nil {
        fmt.Println("打开文件失败:", err)
        return
    }
    defer file.Close()

    // 创建CSV读取器
    reader := csv.NewReader(file)

    // 读取所有行
    records, err := reader.ReadAll()
    if err != nil {
        fmt.Println("读取CSV失败:", err)
        return
    }

    // 遍历输出每一行
    for _, record := range records {
        fmt.Println(record)
    }
}

假设 data.csv 内容如下:

姓名,年龄,城市
张三,25,北京
李四,30,上海

运行程序将输出:

[姓名 年龄 城市]
[张三 25 北京]
[李四 30 上海]

如果想逐行读取以节省内存(适合大文件),可以使用 reader.Read()

for {
    record, err := reader.Read()
    if err == io.EOF {
        break
    }
    if err != nil {
        fmt.Println("读取出错:", err)
        return
    }
    fmt.Println(record)
}

写入CSV文件

使用 csv.NewWriter 可以将数据写入任何实现了 io.Writer 接口的对象,如文件或缓冲区。

以下示例将数据写入新的CSV文件:

package main

import (
    "encoding/csv"
    "os"
)

func main() {
    // 创建或清空文件
    file, err := os.Create("output.csv")
    if err != nil {
        fmt.Println("创建文件失败:", err)
        return
    }
    defer file.Close()

    // 创建CSV写入器
    writer := csv.NewWriter(file)
    defer writer.Flush() // 确保所有数据写入磁盘

    // 准备要写入的数据
    data := [][]string{
        {"姓名", "年龄", "城市"},
        {"张三", "25", "北京"},
        {"李四", "30", "上海"},
    }

    // 逐行写入
    for _, record := range data {
        err := writer.Write(record)
        if err != nil {
            fmt.Println("写入失败:", err)
            return
        }
    }
}

执行后会生成 output.csv 文件,内容为:

AletheaAI AletheaAI

世界上第一个从自然语言描述中生成交互式 AI 角色的多模态 AI 系统。

AletheaAI 83 查看详情 AletheaAI
姓名,年龄,城市
张三,25,北京
李四,30,上海

注意: 必须调用 writer.Flush(),否则数据可能不会真正写入文件。

处理带引号或特殊字符的字段

CSV规范允许字段包含逗号、换行符或引号,这时需要使用双引号包裹字段。encoding/csv 会自动处理这些情况。

例如,某个字段包含逗号:

data := [][]string{
    {"用户", "地址"},
    {"王五", "广东省,深圳市"},
}

写入后CSV内容为:

用户,地址
王五,"广东省,深圳市"

读取时也会正确解析带引号的字段,无需手动处理。

自定义分隔符

有些CSV文件使用制表符(TSV)或其他字符作为分隔符。可以通过设置 Comma 字段来自定义:

reader := csv.NewReader(file)
reader.Comma = '\t' // 使用制表符分隔

writer := csv.NewWriter(file)
writer.Comma = ';'  // 使用分号分隔

这在处理非标准格式时非常有用。

基本上就这些。encoding/csv 简单高效,配合 os 和 bufio 可轻松完成大多数CSV操作。不复杂但容易忽略细节,比如 Flush 和错误处理,写生产代码时要格外注意。

以上就是如何使用Golang encoding/csv处理CSV文件_Golang CSV文件读写示例的详细内容,更多请关注其它相关文章!


# golang  # go语言  # csv  # ai  # go  # 遍历  # ai企业网站建设  # 网站建设怎么赚钱最快  # 推广公司网站  # 邵阳小型网站建设哪家好  # 深圳市  # 广东省  # 是从  # 分隔符  # 如何使用  # 李四  # 自定义  # 北京  # 标准库  # csv文件  # 上海  # 综合评价模型网站建设  # 网站优化外包价格策略  # 卖包包的seo文案  # 河南短视频营销推广平台  # 教育厅网站平台建设  # 金湖seo优化哪家好 


相关栏目: 【 科技资讯46185 】 【 网络学院92790


相关推荐: win11 Snap Layouts怎么用 Win11窗口布局与分屏多任务高效指南【必学】  J*aScript异步迭代器_j*ascript异步遍历  百度网盘网页版入口 百度网盘网页版官方登录网址  QQ网页版官方账号入口 QQ网页版网页版登录指南  一加Ace 6T支持全新明眸护眼:通过了最严苛的护眼小金标认证  免费抖音短视频入口_抖音网页版短视频免费通道  HTML转PPT成品工具有哪些?HTML网页转PPT成品工具大全  怎么在mac上运行html代码_mac运行html代码方法【指南】  晋江读书网页版在线登录 晋江读书电脑版官网  新手怎么开始学化妆 零基础化妆入门教程  谷歌推RCS信息存档功能:公司可监控员工私密信息!  抖音DOU+怎么投最有效 抖音付费推广的ROI提升技巧  漫蛙漫画官方首页 漫蛙2漫画在线阅读入口  qq游戏免费畅玩入口_qq游戏电脑版快速启动  在VS Code中配置和运行Dart程序的完整步骤  iwriter统一登录平台 iwrite账号密码登录页面  Win11怎么关闭触摸屏_Windows 11禁用HID符合标准触摸屏  css滚动动画效果怎么实现_使用Animate.css滚动触发动画类  谷歌google账号怎么注册账号 谷歌账号注册官方流程  Linux如何排查内存不足OOME问题_LinuxOOM分析教程  移动端XML文件怎么转换成Excel 手机和平板上的解决方案  在Go Martini框架中高效服务动态生成图像的实践指南  优化 Jest 模拟:强制未实现函数抛出错误以提升测试效率  如何仅使用CSS更改登录界面背景图像图标的颜色  俄罗斯搜索引擎Yandex指南 附2025年免登录官网入口  Composer的 archive 命令怎么用_快速打包你的PHP项目及其Composer依赖  Yandex官网搜索引擎免登录_俄罗斯Yandex一键直达入口  AO3中文官网链接_AO3网页版稳定镜像站  c++ 命名空间怎么用 c++ namespace使用指南  css滚动区域卡顿如何改善_css滚动问题用will-change优化渲染  汽水音乐在线版入口_汽水音乐网页播放手册  Win11怎么设置鼠标主按键_Win11鼠标左右键功能互换  深入理解Go语言中的指针类型:以*string为例  海棠账号登录入口_登录海棠账户同步阅读记录  使用 Pandas 高效处理 .dat 文件:数据清洗与数值计算实战  德邦快递查询平台 德邦快递物流信息查询入口  谷歌学术网站直达地址 谷歌学术搜索网页版一键进入  Yandex浏览器官方网页版入口 Yandex浏览器最新版官网  J*a递归快速排序中静态变量导致数据累积问题的解决方案  CKEditor 5 自定义构建在React应用中渲染失败的调试与解决  斑马英语APP如何开启夜间护眼阅读_斑马英语APP夜间模式与低蓝光设置教程  印象笔记如何设离线包出差查阅_印象笔记设离线包出差查阅【离线阅读】  蛙漫限时开放最深处链接_蛙漫全站漫画会员同款秒开地址  解决J*aScript中重复选择项的确认对话框显示问题  黑鲨3Pro怎样在相册开漫画风滤镜_iPhone黑鲨3Pro相册开漫画风滤镜【趣味滤镜】  汽水音乐在线解析 汽水音乐在线解析入口  c++如何实现一个简单的软件渲染器_c++从零开始的3D图形学  C++ vector二维数组定义_C++ vector of vector用法  必由学登录入口 必由学官方网站在线访问链接  高德地图公交到站提醒失败如何解决 高德提醒权限设置 

搜索