基于C语言的开源csv解析库:MiniCSV使用示例

news2024/11/17 13:36:22

文章目录

      • MiniCSV简介
      • 官方示例
      • csv文件解析示例
      • CodeBlocks工程下载

MiniCSV简介

之前写了一篇基于C语言字符串操作函数的csv文件解析:C语言解析csv格式文件,本文介绍一个开源简洁的csv解析库的使用:MiniCSV,使用标准C语言设计。

A tiny, fast, simple, single-file, BSD-licensed CSV parsing library in C.
Should be able to handle CSV oddities: multi-lines, escaped rows, escaped characters in escaped rows, empty rows, rows with a variable number of columns, Windows or Unix-style line endings.
Doesn't perform any heap allocations.

一个小型、快速、简单、单文件、BSD许可的C语言CSV解析库。
应该能够处理CSV的奇怪之处:多行、转义行、转义列中的转义字符、空行、列数可变的行、Windows或Unix风格的行结尾。
不执行任何堆分配。

在这里插入图片描述

开源地址

//C语言版本
https://github.com/jedisct1/minicsv

//C++版本
https://gitee.com/null_237_8629/minicsv_cpp

只有一个.c和一个.h文件,使用起来非常简单。

官方示例

#include <stdio.h>
#include <stdlib.h>
#include "stdint.h"

#include "minicsv.h"

int display_cols(char **cols, uint8_t cols_count)
{
    printf("cols=%d: ", cols_count);
    for(int i = 0; i < cols_count; i++)
        printf("[%s]\t", cols[i]);
    printf("\n");
    return 0;
}

int main(void)
{
    char  *cols[7];     //每行逗号的个数+1
    char   str_csv[] = "line1, aa, bb, cc, dd, ee, ff\nline2, 11, 22, 33, 44\nline3, 1,2,3,4,5";
    char  *r = str_csv;
    uint32_t cols_count;        //size_t or uint32_t
    uint8_t cols_max = sizeof(cols) / sizeof(cols[0]);  //最多解析多少列

    /*
        line1, aa, bb, cc, dd, ee, ff
        line2, 11, 22, 33, 44
        line3, 1,2,3,4,5
    */
    printf("csv string: \n%s\n\n", r);

    //解析第1行
    while(*r != NULL)
    {
        r = minicsv_parse_line(r, cols, &cols_count, cols_max);
        //cols_count=当前行解析出的列数
        display_cols(cols, cols_count);
    }

    printf("\nfinish!\n");

    return 0;
}

运行结果:

csv string:
line1, aa, bb, cc, dd, ee, ff
line2, 11, 22, 33, 44
line3, 1,2,3,4,5

cols=7: [line1] [ aa]   [ bb]   [ cc]   [ dd]   [ ee]   [ ff]
cols=5: [line2] [ 11]   [ 22]   [ 33]   [ 44]
cols=6: [line3] [ 1]    [2]     [3]     [4]     [5]

finish!

csv文件解析示例

csv文件内容:

序号,姓名,性别,年龄,职位,兼任,备注
1,张珊,女,29,产品经理
2,李思,男,31,架构师,兼产品副经理,试用
3,王伟,男,27,开发工程师
4,赵丽,女,27,测试工程师,,实习

minicsv解析示例:

#include "stdio.h"
#include "stdlib.h"
#include "stdint.h"
#include "minicsv.h"

#define CSV_PATH    "./demo.csv"
/*
    序号,姓名,性别,年龄,职位,兼任,备注
    1,张珊,女,29,产品经理
    2,李思,男,31,架构师,兼产品副经理,试用
    3,王伟,男,27,开发工程师
    4,赵丽,女,27,测试工程师,,实习
*/
int display_cols(char **cols, uint8_t cols_count);

int main()
{
    FILE *fp = fopen(CSV_PATH, "rw");
    char buf[200];
    char *cols[10];
    uint8_t cols_max = sizeof(cols) / sizeof(cols[0]);

    uint32_t cols_count = 0;
    uint32_t line = 0;

    while(fgets(buf, sizeof(buf) / sizeof(buf[0]), fp) != NULL)
    {
        printf("line = %d, buf = %s", line, buf);
        minicsv_parse_line(buf, cols, &cols_count, cols_max);
        line++;
        display_cols(cols, cols_count);
        memset(buf, 0, sizeof(buf) / sizeof(buf[0]));
    }

    printf("finish! line count = %d\n", line);
    return 0;
}

int display_cols(char **cols, uint8_t cols_count)
{
    printf("cols=%d ", cols_count);
    for(int i = 0; i < cols_count; i++)
        printf("[%s] ", cols[i]);
    printf("\n\n");
    return 0;
}

运行结果:

line = 0, buf = 序号,姓名,性别,年龄,职位,兼任,备注
cols=7 [序号] [姓名] [性别] [年龄] [职位] [兼任] [备注]

line = 1, buf = 1,张珊,,29,产品经理
cols=5 [1] [张珊] [] [29] [产品经理]

line = 2, buf = 2,李思,,31,架构师,兼产品副经理,试用
cols=7 [2] [李思] [] [31] [架构师] [兼产品副经理] [试用]

line = 3, buf = 3,王伟,,27,开发工程师
cols=5 [3] [王伟] [] [27] [开发工程师]

line = 4, buf = 4,赵丽,,27,测试工程师,,实习
cols=7 [4] [赵丽] [] [27] [测试工程师] [] [实习]

finish! line count = 5

CodeBlocks工程下载

  • 基于C语言的MiniCSV解析库示例

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/707310.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Spring Boot 中的 Redis 的数据操作配置和使用

Spring Boot 中的 Redis 的数据操作配置和使用 Redis 是一种高性能的 NoSQL 数据库&#xff0c;它支持多种数据结构&#xff0c;包括字符串、哈希、列表、集合和有序集合。Redis 还提供了丰富的命令&#xff0c;可以对数据进行快速的 CRUD 操作。Spring Boot 是一个基于 Sprin…

数据结构--栈的引用--前中后缀表达式(前部分)

数据结构–栈的引用–前中后缀表达式(前部分) 常见的算数表达式 由三个部分组成: 操作数、运算符、界限符 \color{red}操作数、运算符、界限符 操作数、运算符、界限符 ps:界限符是必不可少的,反映了计算的先后顺序 波兰表达式(让计算机更容易识别的算数表达式) Reverse Po…

高性能分布式缓存Redis(一) 快速实战

一、缓存发展史&缓存分类 1.1、大型网站中缓存的使用 访问量越大&#xff0c;响应力越差&#xff0c;用户体验越差。 引入缓存、示意图如下&#xff1a; 读写策略&#xff1a; Cache Aside Pattern&#xff08;旁路缓存模式&#xff09;Read/Write Through Pattern&am…

AA-TransUNet github: 用于预测任务的注意力增强的TransUNet

文章目录 来源AA_TransUNet架构数据集和预训练模型使用作者 来源 github地址 AA_TransUNet架构 数据集和预训练模型 如果你对本文中使用的数据集&#xff08;降水图和云量数据集&#xff09;感兴趣&#xff0c;请访问SmaAt-UNet了解更多细节。 对于预训练的AA_TransUNet模型…

从磁盘看 IO

计算机上的易失和非易失存储器 常见磁盘可以分为两类&#xff1a;机械磁盘和固态磁盘。 第一类&#xff0c;机械磁盘&#xff0c;也称为硬盘驱动器&#xff08;Hard Disk Driver&#xff09;&#xff0c;通常缩写为 HDD。机械磁 盘主要由盘片和读写磁头组成&#xff0c;数据就…

认识固态继电器及其工作原理

什么是固态继电器&#xff0c;有什么优缺点&#xff1f; 固态继电器 简称SSR&#xff0c;又被称之为“无触点开关”它利用电子元件&#xff08;如双向可控硅等半导体器件&#xff09;的开关特性&#xff0c;可到达无触点无火花地接通和断开电路。 固态继电器工作可靠&#…

1.3 Metasploit 生成SSL加密载荷

在本节中&#xff0c;我们将介绍如何通过使用Metasploit生成加密载荷&#xff0c;以隐藏网络特征。前一章节我们已经通过Metasploit生成了一段明文的ShellCode&#xff0c;但明文的网络传输存在安全隐患&#xff0c;因此本节将介绍如何通过生成SSL证书来加密ShellCode&#xff…

ChatGPT应用工具推荐

ChatGPT作为一种先进的自然生成技术&#xff0c;已经在各个领域展现出了其强大的应用能力&#xff0c;下面将给大家介绍一些ChatGPT的功能应用。 简介 此系统是基于likeadmin—PHP开发的智能对话系统&#xff0c;ChatGPT是一种基于人工智能技术的聊天机器人&#xff0c;它可以…

如何利用AI智能聊天机器人 10秒钟做出一个故事绘本的神奇插件

原文链接&#xff1a;如何利用AI智能聊天机器人10秒钟做出一个故事绘本的神奇插件 C_h~at_&G&&P_T : 以下称为AI智能聊天机器人 一、AI智能聊天机器人4中集成“Stories”插件 对于已经熟悉使用AI智能聊天机器人4 的插件的朋友们&#xff0c;直接在应用市场里搜索…

vtkdicom0.8_vtk9.2_dcmtk3.6.7_qt6.2编译OK

目录 0 结果展示 1 cmake要点 2 编译报错解决 3 参考链接 0 结果展示 1 cmake要点 注意DCMTK_dcmtk_INCLUDE_DIR 2 编译报错解决 D:\Work\C\qt6Work\DCMTK\install\bin\dcmtkcharls.dll : fatal error LNK1107: 文件无效或损坏: 无法在 0x308 处读取 修改&#xff0c;从…

docker安装mysql并且进行连接

1、拉取镜像、在linux中执行命令 docker pull mysql 2、运行容器、在linux中执行命令 docker run -d --name mysql -p 3308:3306 -e MYSQL_ROOT_PASSWORD123456 mysql3、 进入容器、在linux中执行命令 docker ps -a docker exec -it 2a85f05d4090 /bin/bash 4、登录docker中的m…

MySQL日志详解

♥️作者&#xff1a;小刘在C站 ♥️个人主页&#xff1a; 小刘主页 ♥️努力不一定有回报&#xff0c;但一定会有收获加油&#xff01;一起努力&#xff0c;共赴美好人生&#xff01; ♥️学习两年总结出的运维经验&#xff0c;以及思科模拟器全套网络实验教程。专栏&#xf…

基于SpringBoot+vue的校园新闻网站设计与实现

博主介绍&#xff1a; 大家好&#xff0c;我是一名在Java圈混迹十余年的程序员&#xff0c;精通Java编程语言&#xff0c;同时也熟练掌握微信小程序、Python和Android等技术&#xff0c;能够为大家提供全方位的技术支持和交流。 我擅长在JavaWeb、SSH、SSM、SpringBoot等框架…

移动WEB开发之流式布局

css基础&#xff08;一&#xff09;css基础&#xff08;一&#xff09;_上半场结束&#xff0c;中场已休息&#xff0c;下半场ing的博客-CSDN博客Emmet语法Emmet语法_上半场结束&#xff0c;中场已休息&#xff0c;下半场ing的博客-CSDN博客css基础&#xff08;二&#xff09;c…

go语言学习笔记1

go语言简介 ​ GoLang是一种静态强类型、编译型、并发型&#xff0c;并具有垃圾回收功能的编程语言&#xff1b;它可以在不损失应用程序性能的情况下极大的降低代码的复杂性&#xff0c;还可以发挥多核处理器同步多工的优点&#xff0c;并可解决面向对象程序设计的麻烦&#x…

2.ThreadLocalRandom

Random类及其局限性 一般情况下&#xff0c;我们都会使用java.util.Random来生成随机数&#xff08;Math.random()也是使用Random实例生成随机数&#xff09;。 示例 public static void main(String[] args) {Random random new Random();for (int i 0; i < 10; i) {S…

热搜第一!携程宣布每生一个娃奖5万!

6月30日&#xff0c;在线旅游平台携程集团宣布&#xff0c;他们全新推出一项针对全球员工的生育补贴政策。 从2023年7月1日开始&#xff0c;入职满3年的全球员工&#xff0c;无论你是男是女&#xff0c;每生育一个孩子&#xff0c;就将为你获得每年一万元的现金补贴。而这份补贴…

从vue2学习vue3

vue3与vue2的区别 Vue 3在写法上与Vue 2有一些区别&#xff0c;以下是一些常见的区别&#xff1a;引入方式&#xff1a;Vue 2使用Vue全局对象进行引入&#xff0c;而Vue 3使用createApp函数创建应用实例。组件注册&#xff1a;Vue 2中使用Vue.component全局方法或在选项中使用…

Python用if-else实现【猜数字】

文章目录 Python 猜数字案例代码实现&#xff1a;运行效果&#xff1a; Python 猜数字案例 设置一个范围1-100的随机整数变量&#xff0c;通过while循环&#xff0c;配合input语句&#xff0c;判断输入的数字是否等于随机数 无限次机会&#xff0c;直到猜中为止每一次猜不中&am…

1.Springboot基础篇笔记

Springboot基础篇 1.快速上手Springboot 1.基础配置 1.parent 通过配置指定父工程依赖为spring-boot-starter-paerent实现了版本管理的功能&#xff0c;再导入springboot整合其他技术的jar包即可 作用&#xff1a;指定jar包版本信息信息&#xff0c;避免依赖版本冲突 这个s…