【C++】开源:fast-cpp-csv-parser数据解析库配置使用

😏★,°:.☆( ̄▽ ̄)/$:.°★ 😏
这篇文章主要介绍fast-cpp-csv-parser数据解析库配置使用。
无专精则不能成,无涉猎则不能通。——梁启超
欢迎来到我的博客,一起学习,共同进步。
喜欢的朋友可以关注一下,下次更新不迷路🥞

文章目录

    • :smirk:1. 项目介绍
    • :blush:2. 环境配置
    • :satisfied:3. 使用说明

😏1. 项目介绍

项目Github地址:https://github.com/ben-strasser/fast-cpp-csv-parser

fast-cpp-csv-parser 是一个快速、轻量级的C++ CSV解析库,用于解析和处理逗号分隔值(CSV)文件。它专注于提供高性能和低内存占用,并提供简单易用的API。

以下是 fast-cpp-csv-parser 的一些特点和功能:

1.快速解析:fast-cpp-csv-parser 的设计目标之一是提供快速的CSV解析性能。它使用高效的算法和数据结构,以最小的开销解析大型CSV文件。

2.低内存占用:该库在解析过程中使用较少的内存,这对于处理大型CSV文件或有限的内存环境非常有用。

3.简单易用的API:fast-cpp-csv-parser 提供了简洁的API,使CSV文件的解析和访问变得容易。它支持逐行解析、按列索引访问和按列名称访问等。

4.自定义选项:您可以根据需要配置解析器的选项,如分隔符、引号字符、是否跳过空行等。这使得它适应不同的CSV文件格式。

5.跨平台支持:fast-cpp-csv-parser 可在多个平台上运行,包括Windows、Linux和macOS。

fast-cpp-csv-parser 中有 LineReaderCSVReader 两个类,其中LineReader 类用于按行读取文本文件,而不关心是否是CSV格式,它提供了逐行读取文件的功能,可以用于处理任何文本文件;CSVReader 类是 fast-cpp-csv-parser 的主要类,专门用于解析和处理CSV文件,并可进行配置以满足需求。

😊2. 环境配置

该库是一个单头文件的解析库,因此只需将csv.h包含在项目中就可以。

# 编译
g++ -o main main.cpp -lpthread

😆3. 使用说明

CSVReader解析CSV文件示例:

#include <iostream>
#include "csv.h"/*
Name,	Age,	City
a,	10,	city_a
b,	11,	city_b
c,	12,	city_c
d,	13,	city_d
e,  14, city_e
*/int main() {io::CSVReader<3> csv("example.csv");  // 创建CSVReader对象,指定CSV文件名和列数// 设置CSV列名csv.read_header(io::ignore_extra_column, "Name", "Age", "City");std::string name;int age;std::string city;// 逐行解析CSV文件并访问每一列的数据while (csv.read_row(name, age, city)) {// 在此处对解析的数据进行处理std::cout << "Name: " << name << ", Age: " << age << ", City: " << city << std::endl;}return 0;
}

标准库解析CSV示例(对比):

#include <iostream>
#include <fstream>
#include <sstream>
#include <vector>
#include <string>std::vector<std::vector<std::string>> parseCSV(const std::string& filename, char delimiter) {std::vector<std::vector<std::string>> data;std::ifstream file(filename);  // 打开CSV文件if (!file.is_open()) {std::cout << "Failed to open file: " << filename << std::endl;return data;}std::string line;while (std::getline(file, line)) {std::vector<std::string> row;std::stringstream ss(line);std::string cell;while (std::getline(ss, cell, delimiter)) {row.push_back(cell);  // 将每个单元格的数据添加到行向量中}data.push_back(row);  // 将每行数据添加到数据向量中}file.close();  // 关闭文件return data;
}int main() {std::vector<std::vector<std::string>> data = parseCSV("example.csv", ',');  // 解析CSV文件// 遍历解析后的数据并打印到控制台for (const auto& row : data) {for (const auto& cell : row) {std::cout << cell << "\t";}std::cout << std::endl;}return 0;
}

在这里插入图片描述

以上。

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

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

相关文章

perl使用find函数踩坑

前言 写了一个脚本可以同时检查多个仿真log文件&#xff0c;并生成html表格。按照文件修改时间从新到旧排序。然后一直无法使用stath函数获取ctime。 结论&#xff1a;find函数会改变程序执行的当前目录&#xff0c;find(\&process_files, $dir);函数是在$dir目录下运行的…

【AI】人工智能爆发推进器之生成对抗网络

目录 一、什么是生成对抗网络 二、发展历程 三、应用场景 四、小案例&#xff1a;使用GAN生成手写数字 4.1 问题描述 4.2 代码实现 一、什么是生成对抗网络 生成对抗网络&#xff08;Generative Adversarial Networks&#xff0c;简称GAN&#xff09;是深度学习中的一种…

linux开放tomcat 8080端口

1、查看8080是否开放 firewall-cmd --query-port8080/tcp查看已开启的端口 firewall-cmd --list-ports开启防火墙 systemctl start firewalld2、永久开放8080端口 firewall-cmd --zonepublic --add-port8080/tcp --permanent3、重加载&#xff08;重启防火墙&#xff09; …

UDP信号多个电脑的信息传输测试、配置指南

最近要做一个东西&#xff0c;关于一个软件上得到的信号&#xff0c;如何通过连接的局域网&#xff0c;将数据传输出去。我没做过相关的东西&#xff0c;但是我想应该和软件连接数据库的过程大致是差不多的&#xff0c;就一个ip和一个端口号啥的。 一.问题思路 多个设备同时连…

【宇宙猜想】AR文创入驻今日美术馆、北京天文馆等众多展馆,在AR互动中感受科技魅力!

近日&#xff0c;由「宇宙猜想」推出的AR系列文创产品先后入驻今日美术馆、北京天文馆、国家自然博物馆、上海天文馆、国家海洋馆、中华手工展馆等各大馆场并与其展开相关合作。 「宇宙猜想」致力于创造虚拟空间价值&#xff0c;用AR技术与文创产品碰撞出新的火花&#xff0c;为…

SQL语言之DDL

目录结构 SQL语言之DDLDDL操作数据库查询数据库创建数据库删除数据库使用某个数据库案例 DDL操作表创建表查看表结构查询表修改表添加字段删除字段修改字段的类型修改字段名和字段类型 修改表名删除表案例 SQL语言之DDL ​ DDL&#xff1a;数据定义语言&#xff0c;用来定义数…

Unix常用命令整理

Unix常用命令 1. 文件和目录管理命令2. 文本文件处理命令3. 进程管理命令4. 网络管理命令5. 其他常用命令 本文列举了一些Unix操作系统中常用的命令和工具。对于开发人员和系统管理员来说&#xff0c;熟练使用这些命令和工具是非常必要的。此外&#xff0c;还有很多其他的命令和…

数据结构与算法(C语言版)P10——图

1、图的基本概念和术语 前面学过&#xff1a; 线性是一对一树形是一对多 而今天要学习的图形结构是多对多。 图的定义&#xff1a; G(V,E) V&#xff1a;顶点(数据元素)的__有穷非空__集合。E&#xff1a;边的有穷集合。 __有向图&#xff1a;__每条边都是有方向的 __无…

Hive实战:词频统计

文章目录 一、实战概述二、提出任务三、完成任务&#xff08;一&#xff09;准备数据文件1、在虚拟机上创建文本文件2、将文本文件上传到HDFS指定目录 &#xff08;二&#xff09;实现步骤1、启动Hive Metastore服务2、启动Hive客户端3、基于HDFS文件创建外部表4、利用Hive SQL…

物联网协议Coap之Californium CoapServer解析

目录 前言 一、CoapServer对象 1、类对象定义 2、ServerInterface接口 3、CoapServer对象 二、CoapServer服务运行分析 1、CoapServer对象实例化 1.1 调用构造方法 1.2 生成全局配置 1.3 创建Resource对象 1.4-1.8、配置消息传递器、添加CoapResource 1.9-1.12 创建线…

跨境电商企业使用阿里云服务器解决方案

跨境电商具有高并发压力、安全风险监控以及缺乏营销手段等痛点&#xff0c;使用阿里云服务器、负载均衡、国际短信及安全合规等产品店铺搭建工具&#xff0c;阿里云服务器网aliyunfuwuqi.com分享阿里云跨境电商支持&#xff1a; 阿里云助力跨境电商 跨境电商业务痛点&#xf…

dev express 15.2图表绘制性能问题

dev express 15.2 绘制曲线 前端代码 <dxc:ChartControl Grid.Row"1"><dxc:XYDiagram2D EnableAxisXNavigation"True"><dxc:LineSeries2D x:Name"series" CrosshairLabelPattern"{}{A} : {V:F2}"/></dxc:XYDi…

vs c++ 查询mysql 获取返回集数据转化

返回集数据结构[ 指针数组1 -> ["值1", "值2", "值3", ...], 指针数组2 -> ["值1", "值2", "值3", ...], ... ] 改为 指针 -> [ {"字段1": "值1", "字段2": "值2&qu…

Dash中 基本的 callback 5

app.callback 在Dash中&#xff0c;app.callback 被用于创建交互性应用程序&#xff0c;它用于定义一个回调函数&#xff0c;该函数在应用程序中发生特定事件时被触发。回调函数可以修改应用程序的布局或更新图表等内容&#xff0c;从而实现动态交互。 下面是一个简单的 app.…

JMeter

1. 请简要介绍一下JMeter是什么&#xff0c;以及它的主要用途。 Apache JMeter是一个基于Java的压力测试工具&#xff0c;最初设计用于Web应用测试&#xff0c;但现在已经扩展到Apache JMeter是一个基于Java的压力测试工具&#xff0c;最初设计用于Web应用测试&#xff0c;但现…

65内网安全-域环境工作组局域网探针

这篇分为三个部分&#xff0c;基本认知&#xff0c;信息收集&#xff0c;后续探针&#xff0c; 基本认知 分为&#xff0c;名词&#xff0c;域&#xff0c;认知&#xff1b; 完整架构图 名词 dwz称之为军事区&#xff0c;两个防火墙之间的区域称之为dwz&#xff0c;但安全性…

Maven 项目依赖仓库配置详解:pom.xml 中的 repositories 与 Maven 配置文件的调用顺序

Maven 项目依赖仓库配置详解&#xff1a;pom.xml 中的 repositories 与 Maven 配置文件的调用顺序 Maven&#xff08;Apache Maven&#xff09;是一个流行的项目管理工具&#xff0c;广泛用于Java项目的构建、依赖管理以及项目生命周期的管理。在Maven项目中&#xff0c;pom.x…

视频批量处理:随机分割方法,创新剪辑方式

随着数字媒体技术的飞速发展&#xff0c;视频处理已是日常生活和工作中不可或缺的一部分。在处理大量视频时&#xff0c;要一种高效、自动化的方法来满足需求。现在一起来看云炫AI智剪如何批量随机分割视频的批量处理方法&#xff0c;给视频剪辑工作带来创新。 视频随机分割4段…

SAP PP 配置学习(三)

Classification 分类 关联特征值 – (省市联动) 关联特征显示 一个特征是否输入&#xff0c;根据另一个特征来判断。如&#xff1a;只有输入了省份&#xff0c;才需要输入城市。没输省份前&#xff0c;城 市这个特征是不可见的。 修改【城市】特征. 在【城市】特征值中&#xf…

禁止浏览器记住密码和自动填充 element-ui+vue

vue 根据element-ui 自定义密码输入框&#xff0c;防止浏览器 记住密码和自动填充 <template><divclass"el-password el-input":class"[size ? el-input-- size : , { is-disabled: disabled }]"><inputclass"el-input__inner"…