Sep:一个低内存、高性能的CSV文件读写操作.Net开源库
liuian 2025-03-23 21:07 9 浏览
我是编程乐趣,一个10年.Net开发经验老程序员,点击右上方“关注”,每天为你分享开源项目和编程知识。
推荐一个号称最高性能的CSV文件读写操作库,支持AOT/NativeAOT。
01
项目简介
Sep 是一个高性能的 .NET CSV 解析器,具备快速、现代、简洁且高效的数据处理能力。
先进特性:采用 .NET 7+ 和 C# 11+ 的先进特性,例如 Span
简洁API:提供了一个简洁而富有表现力的 API,选项精简,对输入输出的处理透明无隐藏。你看到什么就得到什么。例如,它默认不会自动处理引号的转义/取消转义。
极速性能:通过架构特定和跨平台的 SIMD 矢量化解析技术,支持 64/128/256/512 位路径(如 AVX2、AVX-512(.NET 8.0+)、NEON),实现极速处理。利用 csFastFloat 快速解析浮点数。高效地逐行读取或写入数据,并有详尽的基准测试验证其性能。
多线程加速:通过高效的并行 CSV 解析技术,实现超快速度,比 CsvHelper 快达 35 倍。
低内存占用:智能高效的内存管理策略,在预热后实现零内存分配,包括轻松读取或写入值数组(如特征数据)而无需重复分配内存。
全面测试保障:拥有广泛的代码覆盖率,专注于边缘情况的测试,包括随机模糊测试,确保数据处理的准确性和稳定性。
跨平台兼容:支持 .NET 支持的所有平台和架构,100% 托管,采用现代 C# 编写,代码优美。
可修剪且兼容 AOT/NativeAOT:无反射或动态代码生成,确保完全可修剪且与提前编译(Ahead-of-Time)兼容。简单的控制台测试程序,可执行文件体积小,仅几 MB。
实用主义:遵循 RFC-4180 的核心原则,但在引用和行结束处理上采取实用主义方法。
02
使用方法
简单示例代码
using nietras.SeparatedValues;
// 指定CSV文件的路径
string filePath = "file.csv";
// 使用Sep库创建一个CSV读取器,从文件中读取数据
using var reader = Sep.Reader().FromFile(filePath);
// 遍历CSV文件中的每一行
foreach (var readRow in reader)
{
// 假设我们知道CSV文件的列结构,可以直接通过列名访问数据
string columnA = readRow["A"].ToString();
string columnB = readRow["B"].ToString();
int columnC = readRow["C"].Parse();
double columnD = readRow["D"].Parse();
// 处理每一行的数据
Console.WriteLine($"A: {columnA}, B: {columnB}, C: {columnC}, D: {columnD}");
}
格式化示例代码
using nietras.SeparatedValues;
// 定义一个多行字符串,表示一个CSV格式的数据。
var text = """
A;B;C;D;E;F
Sep;;1;1.2;0.1;0.5
CSV;;2;2.2;0.2;1.5
""";
// 使用Sep库创建一个CSV读取器,自动从标题行推断分隔符。
using var reader = Sep.Reader().FromText(text);
// 根据读取器的规格创建一个写入器,准备将数据写入文本。
using var writer = reader.Spec.Writer().ToText();
// 获取列"B"在标题中的索引位置。
var idx = reader.Header.IndexOf("B");
// 定义一个包含列名的数组。
var nms = new[] { "E", "F" };
// 遍历读取器中的每一行数据。
foreach (var readRow in reader)
{
// 将列"A"读取为只读的字符跨度。
var a = readRow["A"].Span;
// 将列"B"的值转换为字符串。
var b = readRow[idx].ToString();
// 将列"C"的值解析为整数。
var c = readRow["C"].Parse();
// 将列"D"的值解析为浮点数,使用csFastFloat库进行快速解析。
var d = readRow["D"].Parse();
// 将列"E"和"F"的值解析为双精度浮点数的跨度。
var s = readRow[nms].Parse();
// 遍历解析后的数值,并将每个值乘以10。
foreach (ref var v in s) { v *= 10; }
// 开始写入新一行数据,行数据在Dispose时写入。
using var writeRow = writer.NewRow();
// 通过只读的字符跨度设置列"A"的值。
writeRow["A"].Set(a);
// 通过字符串设置列"B"的值。
writeRow["B"].Set(b);
// 通过插值字符串处理器设置列"C"的值,不会产生新的内存分配。
writeRow["C"].Set($"{c * 2}");
// 格式化列"D"的值,将数值除以2。
writeRow["D"].Format(d / 2);
// 直接格式化多个列的值。
writeRow[nms].Format(s);
}
Console.WriteLine(writer.ToString());
03
项目地址
https://github.com/nietras/Sep
- End -
.Net开源项目合集:
https://github.com/bianchenglequ/NetCodeTop
相关推荐
- 用python操作excel、word、pdf非常容易,迅速教会你
-
你会用python操作excel、word、pdf吗?不会也没关系,这篇文章教会你~【文末领取】案例篇幅有限,给大家准备了电子版PDF获取方式:...
- 不同类型的文本、Word文档、Excel文档和图片将它们转换为PDF格式
-
要根据不同类型的文本、Word文档、Excel文档和图片将它们转换为PDF格式,你可以使用Python中的不同库来实现。下面是一个示例代码,展示了如何使用不同的库来处理不同类型的文件并将其转换为PDF...
- 10分钟实现PDF转Word神器!看DeepSeek如何用Python解放打工人
-
开篇痛点每个被PDF折磨过的职场人都懂——领导发来的扫描件要修改,手动抄到Word需要2小时;网上下载的报告想复制数据,却变成乱码…今天我们用Python+DeepSeek,10分钟打造一个智能转换工...
- 第12天 | 12天搞定Python,word和pdf
-
其实,Python除了对excel的支持很nice之外,对word、ppt和pdf也不赖的,上一篇《第12天|12天搞定Python,让excel飞起来》说了excel方面的内容,这一篇补上Py...
- 用python轻松操作excel、word、pdf吗?这篇文章教会你!拿走不谢
-
你会用python操作excel、word、pdf吗?不会也没关系,这篇文章教会你~【文末领取】案例篇幅有限,给大家准备了电子版PDF获取方式:...
- Python开发打印服务(1)
-
Python开发打印服务(1)1.需求背景在项目开发中,我们经常会遇到打印预览、打印的需求。比如:我们在开发进销存或者其他系统应用时,经常会按照客户的需求来定制报表等。在Web项目中,实现打印预览...
- 零代码编程:用ChatGPT将PDF文件的表格批量转为Excel表格
-
电脑中有几百个PDF文件,文件内容格式一致,每个PDF文件第一页是一个表格。想把这几百个PDF文件里面的表格都提取出来,转为excel表,该怎么办?打开ChatGPT(一定要用GPT4,编程能力很强。...
- 用python操作excel、word、pdf非常迅速方便,迅速教会你
-
你会用python操作excel、word、pdf吗?不会也没关系,这篇文章教会你~【文末领取】案例篇幅有限,给大家准备了电子版PDF获取方式:...
- PDF转换技巧:如何免费将 PDF 转换为 Excel
-
随着数字文档的使用不断增加,对高效和值得信赖的文档转换工具的需求也在增加。将PDF文件转换为Excel电子表格(XLS)可能具有挑战性,但这篇文章旨在缓解这些困难。这是带有分步说明的指南。...
- PDF转Excel要收费?python几行代码帮你免费搞定(附代码)
-
写在前面经常在学习或工作中需要从PDF获取一些表格数据,直接用PDF阅读器复制的话,很难复制出来,使用PDF转Excel的软件,又需要收费。这时候,可以使用我们强大的python,几行代码就能把pdf...
- python将PDF格式文档转换为excel文档
-
首先安装pdfplumber库pipinstallpdfplumberopenpyxl然后转换#导入两个模块importpdfplumberimportpandasaspd...
- 用DEEPSEEK写PDF转为Excel 程序
-
今天学校发了《2027通用版普通高校拟在山东招生专业(类)选考科目要求》(本科)文件为PDF版要转为化Excel用DEEPSEEK开发过程提问:写一个把PDF内容按着原来格式转化为EXCELL表格电脑...
- 用DeepSeek+Trae 自己写PDF表格转为EXCEL表格
-
如何将下面PDF表格转为EXCEL能更好统计在TRAE提问:新建窗口-选择文件夹-写一个PDF转excel电脑程序:样式不变,界面有选择文件,有输出文件,显示进度及页码,开始,暂停,退出,实现所...
- Python一行代码实现PDF转Excel
-
第三方包tabula工具适用于从PDF中提取可复制(非图片格式)的表格数据,并输出表格安装pipinstalltabula-py函数调用df=tabula.read_pdf("PDF文件...
- Python教程:python字典zip函数用法 - 学习如何操作字典
-
知识星球:写代码那些事如果你有收获|欢迎|点赞|关注|转发这里会定期更新|大厂的开发|架构|方案设计这里也会更新|如何摸鱼|抓虾欢迎来到写代码那些事!在Python编程中,字典(Dictionary)...
- 一周热门
-
-
Python实现人事自动打卡,再也不会被批评
-
Psutil + Flask + Pyecharts + Bootstrap 开发动态可视化系统监控
-
一个解决支持HTML/CSS/JS网页转PDF(高质量)的终极解决方案
-
【验证码逆向专栏】vaptcha 手势验证码逆向分析
-
再见Swagger UI 国人开源了一款超好用的 API 文档生成框架,真香
-
网页转成pdf文件的经验分享 网页转成pdf文件的经验分享怎么弄
-
C++ std::vector 简介
-
python使用fitz模块提取pdf中的图片
-
《人人译客》如何规划你的移动电商网站(2)
-
Jupyterhub安装教程 jupyter怎么安装包
-
- 最近发表
-
- 用python操作excel、word、pdf非常容易,迅速教会你
- 不同类型的文本、Word文档、Excel文档和图片将它们转换为PDF格式
- 10分钟实现PDF转Word神器!看DeepSeek如何用Python解放打工人
- 第12天 | 12天搞定Python,word和pdf
- 用python轻松操作excel、word、pdf吗?这篇文章教会你!拿走不谢
- Python开发打印服务(1)
- 零代码编程:用ChatGPT将PDF文件的表格批量转为Excel表格
- 用python操作excel、word、pdf非常迅速方便,迅速教会你
- PDF转换技巧:如何免费将 PDF 转换为 Excel
- PDF转Excel要收费?python几行代码帮你免费搞定(附代码)
- 标签列表
-
- python判断字典是否为空 (50)
- crontab每周一执行 (48)
- aes和des区别 (43)
- bash脚本和shell脚本的区别 (35)
- canvas库 (33)
- dataframe筛选满足条件的行 (35)
- gitlab日志 (33)
- lua xpcall (36)
- blob转json (33)
- python判断是否在列表中 (34)
- python html转pdf (36)
- 安装指定版本npm (37)
- idea搜索jar包内容 (33)
- css鼠标悬停出现隐藏的文字 (34)
- linux nacos启动命令 (33)
- gitlab 日志 (36)
- adb pull (37)
- table.render (33)
- uniapp textarea (33)
- python判断元素在不在列表里 (34)
- python 字典删除元素 (34)
- react-admin (33)
- vscode切换git分支 (35)
- python bytes转16进制 (35)
- grep前后几行 (34)