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

这篇具有很好参考价值的文章主要介绍了基于C语言的开源csv解析库:MiniCSV使用示例。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

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语言的开源csv解析库:MiniCSV使用示例,c语言,csv,csv文件,C++,解析

开源地址

//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,测试工程师,,实习

基于C语言的开源csv解析库:MiniCSV使用示例,c语言,csv,csv文件,C++,解析

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;
}

运行结果:文章来源地址https://www.toymoban.com/news/detail-612783.html

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解析库示例

到了这里,关于基于C语言的开源csv解析库:MiniCSV使用示例的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 若依使用easyexcel读取解析excel文件示例

    睿洛医疗 目标:结构化自定义列数和列标题的excel数据。   创建数据类 创建监听类 创建数据类 创建监听类 参考:EasyExcel

    2024年02月11日
    浏览(30)
  • 【通义千问】大模型Qwen GitHub开源工程学习笔记(2)--使用Qwen进行推理的示例代码解析,及transformers的使用

    如希望使用Qwen-chat进行推理,所需要写的只是如下所示的数行代码。 请确保你使用的是最新代码,并指定正确的模型名称和路径,如 Qwen/Qwen-7B-Chat 和 Qwen/Qwen-14B-Chat 这里给出了一段代码

    2024年02月08日
    浏览(35)
  • 使用代码下载开源的大模型文件示例以及中文微调llama资源汇总:

    一、下载示例  二、资源汇总 Chinese Llama 2 7B 链接:LinkSoul/Chinese-Llama-2-7b · Hugging Face OpenBuddy-LLaMA2-13B 链接:OpenBuddy/openbuddy-llama2-13b-v8.1-fp16 · Hugging Face firefly-llama2-13b 链接:GitHub - yangjianxin1/Firefly: Firefly(流萤): 中文对话式大语言模型(全量微调+QLoRA),支持微调Llma2、Llama、Qwen、

    2024年02月13日
    浏览(34)
  • R语言【utils】——write.table(),write.csv(),write.csv2():将数据写入文件

    Package  utils  version 4.2.0 参数【x】 :要写入的对象,最好是矩阵或数据帧。如果不是,则尝试将其强制转换为数据帧。 参数【file】 :命名文件的字符串或打开用于写入的连接。“”表示向控制台输出。 参数【append】 :逻辑值。只有当 参数【file】 是一个字符串时才相关。

    2024年01月22日
    浏览(35)
  • 基于Python的语义视频搜索:使用结构化相似度测量指数(SSMI)和图像字幕网络实现的分步解析与实战示例

    在如今这个视频信息愈加丰富的时代,如何有效地搜索、分析和管理大量的视频数据变得越来越重要。本文旨在解释我们如何使用Python和一些先进的计算机视觉技术来实现对视频库的语义搜索,即,我们可以通过自动生成的摘要来搜索视频数据库。 在这个过程中,我们首先将

    2024年02月16日
    浏览(35)
  • 开源 SPL 助力 JAVA 处理公共数据文件(txt \csv \ json \xml \xls)

    在 JAVA 应用中经常要处理 txtcsvjsonxmlxls 这类公共格式的数据文件,直接用 JAVA 硬写会非常麻烦,通常要借助一些现成的开源包,但这些开源包也都有各自的不足。 解析库 。这种类库解决了从外部文件到内部对象的问题,比硬编码取数好写,常见的有解析 txtcsv 的 OpenCSV,

    2024年02月01日
    浏览(36)
  • c语言将csv文件中的XY轴数据转换为html波形图

    目标: c语言实现一个最简化的csv转html波形图显示方案。 csv文件格式: 共两行数据,第一行是x轴数据,第二行是y轴数据。 csv文件名分为3段: 波形图名称,x轴名称,y轴名称。 c代码: int csv2html_wave(csv_file_name,html_file_name); html代码: 效果图: TODO: XY轴的箭头。 XY轴显示范围

    2024年01月17日
    浏览(30)
  • Python中使用csv读取csv文件中的指定列

    第一种方法,使用next()获取列名,然后使用index定位列名 另一种方法是使用csv.DictReader()函数,将csv文件的每一行读成字典,代码更为简洁。

    2024年02月04日
    浏览(49)
  • 常用python代码大全-python使用csv模块进行CSV文件操作

    CSV文件是一种常见的数据存储格式,由逗号分隔的值组成。Python的csv模块提供了读取和写入CSV文件的功能。 以下是一个使用csv模块进行CSV文件操作的代码示例: 在上面的代码中,我们首先使用 open() 函数打开一个名为 example.csv 的CSV文件,并指定模式为 \\\'r\\\' ,表示只读模式。然

    2024年01月17日
    浏览(34)
  • Unity使用CSV读写表格文件

    CSV(逗号分隔值文件格式):以纯文本形式存储表格数据。 1.挂载脚本 2.回到unity,在脚本组件上输入数据 3.右击Assets文件夹,点击Refresh,可以看到多出了一个StreamingAssets文件夹和data文件 4.使用记事本打开,可以看到写入的数据(使用excel打开会出现乱码,使用wps不会,这里

    2024年02月16日
    浏览(25)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包