基于C語(yǔ)言的開源csv解析庫(kù)MiniCSV的使用示例
MiniCSV簡(jiǎn)介
之前寫了一篇基于C語(yǔ)言字符串操作函數(shù)的csv文件解析:C語(yǔ)言解析csv格式文件,本文介紹一個(gè)開源簡(jiǎn)潔的csv解析庫(kù)的使用:MiniCSV,使用標(biāo)準(zhǔn)C語(yǔ)言設(shè)計(jì)。
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.
一個(gè)小型、快速、簡(jiǎn)單、單文件、BSD許可的C語(yǔ)言CSV解析庫(kù)。
應(yīng)該能夠處理CSV的奇怪之處:多行、轉(zhuǎn)義行、轉(zhuǎn)義列中的轉(zhuǎn)義字符、空行、列數(shù)可變的行、Windows或Unix風(fēng)格的行結(jié)尾。
不執(zhí)行任何堆分配。
開源地址
C語(yǔ)言版本
https://github.com/jedisct1/minicsv
C++版本
https://gitee.com/null_237_8629/minicsv_cpp
只有一個(gè).c和一個(gè).h文件,使用起來非常簡(jiǎn)單。
官方示例
#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]; //每行逗號(hào)的個(gè)數(shù)+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=當(dāng)前行解析出的列數(shù) display_cols(cols, cols_count); } printf("\nfinish!\n"); return 0; }
運(yùn)行結(jié)果:
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文件內(nèi)容:
序號(hào),姓名,性別,年齡,職位,兼任,備注
1,張珊,女,29,產(chǎn)品經(jīng)理
2,李思,男,31,架構(gòu)師,兼產(chǎn)品副經(jīng)理,試用
3,王偉,男,27,開發(fā)工程師
4,趙麗,女,27,測(cè)試工程師,,實(shí)習(xí)
minicsv解析示例:
#include "stdio.h" #include "stdlib.h" #include "stdint.h" #include "minicsv.h" #define CSV_PATH "./demo.csv" /* 序號(hào),姓名,性別,年齡,職位,兼任,備注 1,張珊,女,29,產(chǎn)品經(jīng)理 2,李思,男,31,架構(gòu)師,兼產(chǎn)品副經(jīng)理,試用 3,王偉,男,27,開發(fā)工程師 4,趙麗,女,27,測(cè)試工程師,,實(shí)習(xí) */ 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; }
運(yùn)行結(jié)果:
line = 0, buf = 序號(hào),姓名,性別,年齡,職位,兼任,備注
cols=7 [序號(hào)] [姓名] [性別] [年齡] [職位] [兼任] [備注]
line = 1, buf = 1,張珊,女,29,產(chǎn)品經(jīng)理
cols=5 [1] [張珊] [女] [29] [產(chǎn)品經(jīng)理]
line = 2, buf = 2,李思,男,31,架構(gòu)師,兼產(chǎn)品副經(jīng)理,試用
cols=7 [2] [李思] [男] [31] [架構(gòu)師] [兼產(chǎn)品副經(jīng)理] [試用]
line = 3, buf = 3,王偉,男,27,開發(fā)工程師
cols=5 [3] [王偉] [男] [27] [開發(fā)工程師]
line = 4, buf = 4,趙麗,女,27,測(cè)試工程師,,實(shí)習(xí)
cols=7 [4] [趙麗] [女] [27] [測(cè)試工程師] [] [實(shí)習(xí)]
finish! line count = 5
到此這篇關(guān)于基于C語(yǔ)言的開源csv解析庫(kù)MiniCSV的使用示例的文章就介紹到這了,更多相關(guān)C語(yǔ)言 MiniCSV內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
C++中為何推薦要把基類析構(gòu)函數(shù)設(shè)置成虛函數(shù)
這篇文章主要介紹了C++中為何推薦要把基類析構(gòu)函數(shù)設(shè)置成虛函數(shù)問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-12-12C語(yǔ)言鏈表實(shí)現(xiàn)工資管理系統(tǒng)
這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言鏈表實(shí)現(xiàn)工資管理系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-02-02C++析構(gòu)函數(shù)內(nèi)部工作機(jī)制詳解
析構(gòu)函數(shù)(Destructor)也是一種特殊的成員函數(shù),沒有返回值,不需要程序員顯式調(diào)用(程序員也沒法顯式調(diào)用),而是在銷毀對(duì)象時(shí)自動(dòng)執(zhí)行。構(gòu)造函數(shù)的名字和類名相同,而析構(gòu)函數(shù)的名字是在類名前面加一個(gè)~符號(hào)2023-02-02一文詳解C++子類函數(shù)為什么不能重載父類函數(shù)
這篇文章主要介紹了一文詳解C++子類函數(shù)為什么不能重載父類函數(shù),文章圍繞主題展開詳細(xì)的內(nèi)容戒殺,具有一定的參考價(jià)值,需要的朋友可以參考一下2022-09-09深入詳解C編寫Windows服務(wù)程序的五個(gè)步驟
本篇文章介紹了,使用C編寫Windows服務(wù)程序的五個(gè)步驟的詳細(xì)概述。需要的朋友參考下2013-05-05利用C語(yǔ)言編寫一個(gè)無限循環(huán)語(yǔ)句
這篇文章主要介紹了利用C語(yǔ)言編寫一個(gè)無限循環(huán)語(yǔ)句問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-11-11C++中靜態(tài)初始化數(shù)組與動(dòng)態(tài)初始化數(shù)組詳解
今天小編就為大家分享一篇C++中靜態(tài)初始化數(shù)組與動(dòng)態(tài)初始化數(shù)組詳解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2018-07-07關(guān)于C語(yǔ)言操作符的那些事(超級(jí)全)
這篇文章主要給大家介紹了關(guān)于C語(yǔ)言操作符的那些事兒,c語(yǔ)言的操作符有很多,包括算術(shù)操作符、移位操作符、位操作符、賦值操作符、單目操作符、關(guān)系操作符、邏輯操作符、條件操作符、逗號(hào)表達(dá)式、下標(biāo)引用、函數(shù)調(diào)用和結(jié)構(gòu)成員,需要的朋友可以參考下2021-08-08