C语言读取写入CSV文件基础入门篇

2023-11-08

什么是CSV?

大量C语言项目课设、小游戏源码 压 缩 包 免 费 下 载 链 接 如 下:

c语言项目课设小游戏源码资料压缩包.zip-C文档类资源-CSDN下载c语言项目课设小游戏源码资料压缩包.zipc语言项目课设小游戏源码资料压缩包.zipc语言项目课设小更多下载资源、学习资料请访问CSDN下载频道.https://download.csdn.net/download/chengxuyuanlaow/86749012CSV 是一种以纯文本形式存储的表格数据,具体介绍如下(来自维基百科):

逗号分隔值(Comma-Separated Values,CSV,有时也称为字符分隔值,因为分隔字符也可以不是逗号),其文件以纯文本形式存储表格数据(数字和文本)。纯文本意味着该文件是一个字符序列,不含必须像二进制数字那样被解读的数据。CSV文件由任意数目的记录组成,记录间以某种换行符分隔;每条记录由字段组成,字段间的分隔符是其它字符或字符串,最常见的是逗号或制表符。通常,所有记录都有完全相同的字段序列。

简单的说,CSV 是一种通用的、相对简单的表格文件格式,最广泛的应用就是在不同程序之间转移表格数据。值得注意的是,CSV 并没有一种单一的、定义明确的格式(虽然有一个 RFC 4180 的标准),一般地,CSV 文件具有如下特征:

  1. 纯文本,使用某个特定的字符集保存,例如 ASCII、Unicode 等
  2. 由一条条记录组成,一般每一行代表一条记录
  3. 每条记录被分隔符划分为不同的字段,最常见的分隔符是逗号,毕竟其中文名叫逗号分隔值:)
  4. 每条记录相同的字段序列

因为CSV 并没有一种单一的、定义明确的格式,因此下面的内容以最常见的格式为例,即逗号(,)分隔字段,换行符(\n)分隔记录。

C 语言写入 CSV 文件

首先我们来了解如何写入一个 CSV 文件,下面是示例代码:

// 1-1.c
#include <stdio.h>
#include <stdlib.h>

int main()
{
    FILE *fp = fopen("tmp.csv", "w+");
    if (fp == NULL) {
        fprintf(stderr, "fopen() failed.\n");
        exit(EXIT_FAILURE);
    }

    fprintf(fp, "ID,Name,Points\n");
    fprintf(fp, "1,qwe,1.1\n");

    int id = 2;
    char *name = "asd";
    float point = 2.2;
    fprintf(fp, "%d,%s,%f\n", id, name, point);

    fclose(fp);
    return 0;
}

上述代码中,首先便是打开一个 CSV 文件,若打开失败,那么则报告出错结束程序。接下来便是向打开的 CSV 文件写入内容:

fprintf(fp, "ID,Name,Points\n");

常见的CSV文件的分隔符是逗号(,),被分隔符分开的字段会位于不同的列。在上述语句中,IDNamePoints 被分隔符分开,因此这个CSV文件共有3列,分别是IDNamePoints

CSV文件是由一条条记录组成的,常见划分不同记录的符号是换行符(\n)。在上述语句中,IDNamePoints 分别属于同一行上的不同三列,很显然,这条记录是表头。

接下来的 fprintf(fp, "1,qwe,1.1\n"); 语句写入的记录为 1、qwe、1.1,分为三列,正好对应于 ID=1、Name=qwe、Points=1.1。前一条语句采用了直接写入,但很多时候我们的值是变化的,幸运的是,CSV的写入同样支持格式化写入,代码如下:

int id = 2;
char *name = "asd";
float point = 2.2;
fprintf(fp, "%d,%s,%f\n", id, name, point);

最后写入的记录为 2(ID)、asd(Name)、2.2(Points)。运行程序,查看 CSV 文件内容,结果为:

C 语言读取 CSV 文件

示例程序如下:

// 1-2.c
#include <stdio.h>
#include <stdlib.h>
#include <string.h>

int main()
{
    FILE *fp = fopen("tmp.csv", "r");
    if (fp == NULL) {
        fprintf(stderr, "fopen() failed.\n");
        exit(EXIT_FAILURE);
    }

    char row[80];
    char *token;
    while (fgets(row, 80, fp) != NULL) {
        printf("Row: %s", row);
        token = strtok(row, ","); 
        while (token != NULL) {
            printf("Token: %s\n", token);
            token = strtok(NULL, ",");
        }
    }

    fclose(fp);
    return 0;
}

首先要打开将要读取的CSV文件,这一步和写入一样,不再赘述。

while (fgets(row, 80, fp) != NULL) {
    printf("Row: %s", row);
    // other code
}

因为CSV文件是一个纯文本文件,因此我们可以使用 fgets 函数一行一行地进行读取,这样读取得到的便是CSV文件中一条条记录。接下来要做的就是将不同字段从记录中分隔出来:

token = strtok(row, ","); 
while (token != NULL) {
    printf("Token: %s\n", token);
    token = strtok(NULL, ",");
}

char* strtok(char *restrict str, const char *restrict delim) 函数可以把字符串 str 按照给定的分隔符 delim 进行分隔,如果要解析仍是之前同一个字符串时,需要把 str 设为 NULL。因此 token = strtok(row, ","); 这条语句会尝试用逗号(,)来分割刚刚读取得到的记录,同时使用一个 while (token != NULL) 循环来不断进行分割,直到无法分隔为止,这样就得到每个字段的值。

程序运行输出的结果如下:

$ clang 1-2.c -o 1-2
$ ./1-2
Row: ID,Name,Points
Token: ID
Token: Name
Token: Points

Row: 1,qwe,1.1
Token: 1
Token: qwe
Token: 1.1

Row: 2,asd,2.200000
Token: 2
Token: asd
Token: 2.200000

最后总结一下,CSV 文件和普通文件一样,无论读写都需要先打开文件。而后写入或读取时所用的函数和普通文件没有区别,唯一需要注意的是,CSV 文件通过特定的分隔符来区分字段和记录:

  • 用换行符(\n)来区分记录,一条记录会占据CSV文件的一行
  • 用逗号(,)来区分一条记录中的不同字段,每个字段会单独占据一列

如果想要了解进阶的 C 语言读写 CSV 文件的有关内容,欢迎接着阅读进阶篇

 

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

C语言读取写入CSV文件基础入门篇 的相关文章

随机推荐

  • 【DTale】数据分析强大工具DTale的使用

    简单介绍 使用dtale 启动 数据加载 功能介绍 主菜单选项 0 切换语言 1 创建列 2 汇总数据 3 缺失率分析 4 绘图 5 高亮功能 6 代码导出 数据导出 列菜单功能 1 冻结 2 隐藏和删除 3 替换和类型转换 4 描述性统计
  • tomcat的多实例和动静分离

    多实例 在一台服务器上有多个tomcat服务 配置成全局变量 方便后面传参 安装tomcat 安装好 jdk后编译安装tomcat cd opt tar zxvf apache tomcat 9 0 16 tar gz mkdir usr
  • android蓝牙键盘光标,罗技K810背光蓝牙键盘快捷键大全

    最近入手了一款罗技K810背光蓝牙键盘 该怎么使用键盘的快捷键实现快捷操作呢 下面我们就来看看罗技K810背光蓝牙键盘快捷键大全 需要的朋友可以参考下 一 PC版键盘上的WIN键相当于MAC iOS系统的command键 文本输入状态下 S
  • WiFi6技术细节简介

    WiFi6技术细节简介 WiFi的历史发展 WiFi历史发展中技术的迭代 WiFi6的新型技术优势 OFDMA 双向MU MMIO 多用户多输入输出 1024QAM 空间频率复用SR BSS Coloring WAP3 实际使用带来的用户体
  • docker: Error response from daemon: could not select device driver ““ with capabilities: [[gpu]].

    需要安装nvidia container toolkit或nvidia container runtime 包含nvidia container toolkit distribution etc os release echo ID VER
  • 使用 React Hooks + mock + antd构建一个完整且漂亮的 todoList

    实现效果 搭建项目 使用 create react app 快速创建一个项目 删除不必要的文件 保留文件如下 目录说明 index js 项目入口文件 index less 样式 mock js 模拟 todo 数据 TodoList js
  • 6基于二阶锥规划的主动配电网最优潮流求解

    matlab代码 6 基于二阶锥规划的主动配电网最优潮流求解 参考文献 主动配电网多源协同运行优化研究 乔珊 摘要 最优潮流研究在配 电网规划运行 中不可或缺 且在大量分布式能源接入 的主动配 电网环境下尤 为重要 传统的启发式算法 在全局
  • statsmodels.regression.linear_model.RegressionResults

    statsmodels regression linear model RegressionResults class statsmodels regression linear model RegressionResults model
  • vue上传文件夹,将file类型转为binary类型传参到后台

  • ES6-promise小技巧

    Promise all 从Promise all返回的主promise在所有成员promise都完成后才会执行 如果这些promise中有任何一个被拒绝 reject error 住promise就会被拒绝 并丢弃来自其他所有promise
  • 【Jupyter Notebook】安装及使用

    知识目录 前言 一 Jupyter Notebook安装使用 1 1 Jupyter Notebook的三种打开方式 1 点击Anaconda Prompt打开 2 点击Jupyter Notebook打开 3 使用Powershell打开
  • [计算机毕业设计]机器学习的数据驱动股票价格预测

    前言 大四是整个大学期间最忙碌的时光 一边要忙着准备考研 考公 考教资或者实习为毕业后面临的就业升学做准备 一边要为毕业设计耗费大量精力 近几年各个学校要求的毕设项目越来越难 有不少课题是研究生级别难度的 对本科同学来说是充满挑战 为帮助大
  • 算法设计与分析——0/1背包问题

    问题描述 给定n个重量为 w1 w2 wn 价值为 v1 v2 vn 的物品和一个容量为C的背包 0 1背包问题是求这些物品中的一个 最有价值的子集 并且能够装入背包中 基本算法思想 暴力法 用暴力法解决0 1背包问题 需要考虑给定n个物品
  • 概率密度函数

    概率密度函数 Probability Density Function 简称PDF 是描述随机变量的概率分布的函数 它对于连续型随机变量来说是非常重要的概念 PDF可以用来描述变量在不同取值上的概率分布情况 对于一个连续型随机变量X 其概率
  • 记忆化搜索 (蒟蒻练习生)

    定义 记忆化搜索是一种通过记录已经遍历过的状态的信息 从而避免对同一状态重复遍历的搜索实现方式 因为记忆化搜索确保了每个状态只访问一次 它也是一种常见的动态规划实现方式 引入 题目见 NOIP2005 采药 朴素的 DFS 做法 很容易实现
  • Python web自动化测试 —— 文件上传

    文件上传三种方式 一 查看元素标签 如果是input 则可以参照文本框输入的形式进行文件上传 方法 和用户输入是一样的 使用send keys 1 2 3 4 5 步骤 1 找到定位元素 2 输入文件路径 ele driver find e
  • ios android 字体大小,并排文字在ios上字体变大,安卓上正常显示

    IOS页面 安卓页面 复现代码 公告 疑情公告 notice notice export default data return notice 中民筑友码垛机作业区域一号工位发 疑似闯入行为中民筑友码垛机作业区域一号工位发 疑似闯入行为 发
  • Golang中结构体Struct

    前言 这里总结的Golang 笔记只适合有点编程基础的人看 比如Java 往期内容 Golang学习 day1 变量 类型 Golang学习 指针 循环控制相关 循环结构控制 包函数的使用 异常处理 数组 老奶奶可以看懂的切片 老奶奶可以看
  • C++之extern和static用法和区别

    目录 声明和定义的区别 关键字extern 作用 用法总结 关键字static 全局变量和全局静态变量区别 局部静态变量 静态函数 声明和定义的区别 变量定义 用于为变量分配存储空间 还可为变量指定初始值 程序中 变量有且仅有一个定义 变量
  • C语言读取写入CSV文件基础入门篇

    什么是CSV 大量C语言项目课设 小游戏源码 压 缩 包 免 费 下 载 链 接 如 下 c语言项目课设小游戏源码资料压缩包 zip C文档类资源 CSDN下载c语言项目课设小游戏源码资料压缩包 zipc语言项目课设小游戏源码资料压缩包 z