.NET C# 读写CSV及转换DataTable

目录

  • .NET C# 读写CSV及转换DataTable
    • 1. 依赖库
    • 2. CSVUtil
      • 2.1 CSV 转 DataTable
      • 2.2 DataTable 转 CSV 文本
      • 2.3 DataTable 转 CSV
      • 2.4 私有方法

.NET C# 读写CSV及转换DataTable

1. 依赖库

using System.Data;
using System.IO;
using System.Text;
using System.Text.RegularExpressions;

2. CSVUtil

2.1 CSV 转 DataTable

/// <summary>
/// CSV 转 DataTable
/// </summary>
/// <param name="csvFilePath">CSV文件路径</param>
/// <param name="separator">间隔符,默认为","</param>
/// <returns>结果DataTable</returns>
public static DataTable? FromCSV(string csvFilePath, string separator = ",")
{DataTable dt = new DataTable();string separatorTemp = Guid.NewGuid().ToString().Replace("-", "");List<string[]?> lineArrayList = ReadCsvLines(csvFilePath, separator, separatorTemp);if (lineArrayList.Count < 1){return null;}int maxColumnCount = 0;lineArrayList.ForEach(l =>{if(l != null && l.Length > maxColumnCount){maxColumnCount = l.Length;}});string[]? headerLineArray = lineArrayList[0];for (int columnIdx = 0; columnIdx < maxColumnCount; columnIdx++){string? columnName = null;if (headerLineArray != null && headerLineArray.Length > columnIdx){columnName = headerLineArray[columnIdx]?.Trim('"')?.Replace(separatorTemp, separator);}if (string.IsNullOrEmpty(columnName)){columnName = $"column_{columnIdx + 1}";}string columnNameTemp = columnName;int tag = 0;while (dt.Columns.Contains(columnNameTemp)){columnNameTemp = $"{columnName}_{++tag}";}dt.Columns.Add(columnNameTemp);}for (int rowIdx = 1; rowIdx < lineArrayList.Count; rowIdx++){string[]? lineArray = lineArrayList[rowIdx];DataRow dataRow = dt.NewRow();for (int columnIdx = 0; columnIdx < maxColumnCount; columnIdx++){if (lineArray != null && lineArray.Length > columnIdx){dataRow[columnIdx] = lineArray[columnIdx]?.Trim('\"')?.Replace(separatorTemp, separator);}}dt.Rows.Add(dataRow);}return dt;
}

2.2 DataTable 转 CSV 文本

/// <summary>
/// DataTable 转 CSV 文本
/// </summary>
/// <param name="dt">DataTable实例</param>
/// <param name="separator">间隔符,默认为","</param>
/// <returns>CSV 文本</returns>
public static string ToCsvText(DataTable dt, string separator = ",")
{string csvText = string.Empty;string currentLine = string.Empty;for (int columnIdx = 0; columnIdx < dt.Columns.Count; columnIdx++){currentLine += $"\"{dt.Columns[columnIdx].ColumnName}\"{separator}";}currentLine = currentLine[..^separator.Length];csvText += currentLine;for (int rowIdx = 0; rowIdx < dt.Rows.Count; rowIdx++){currentLine = string.Empty;for (int columnIdx = 0; columnIdx < dt.Columns.Count; columnIdx++){currentLine += $"\"{dt.Rows[rowIdx][columnIdx]}\"{separator}";}currentLine = currentLine[..^separator.Length];csvText += Environment.NewLine + currentLine;}return csvText;
}

2.3 DataTable 转 CSV

/// <summary>
/// DataTable 转 CSV
/// </summary>
/// <param name="dt">DataTable实例</param>
/// <param name="csvFilePath">CSV文件路径</param>
/// <param name="separator">间隔符,默认为","</param>
/// <param name="cover">覆盖CSV文件,默认为True,若仅追加,则传False</param>
public static void ToCSV(DataTable dt, string csvFilePath, string separator = ",", bool cover = true)
{FileStream? fs = null;StreamWriter? sw = null;string csvText = ToCsvText(dt, separator);try{if (!File.Exists(csvFilePath) || cover){fs = new FileStream(csvFilePath, FileMode.Create, FileAccess.Write);sw = new StreamWriter(fs, Encoding.UTF8);}else{fs = new FileStream(csvFilePath, FileMode.Append, FileAccess.Write);sw = new StreamWriter(fs, Encoding.UTF8);sw.WriteLine();}sw.Write(csvText);}catch (Exception ex){// 异常处理...}finally{try { sw?.Close(); } catch { }try { fs?.Close(); } catch { }}
}

2.4 私有方法

private static List<string[]?> ReadCsvLines(string csvFilePath, string separator, string separatorTemp)
{FileStream? fs = null;StreamReader? sr = null;List<string[]?> lineArrayList = new List<string[]?>();try{fs = new FileStream(csvFilePath, FileMode.Open, FileAccess.Read);sr = new StreamReader(fs, Encoding.UTF8);string? currentLine = string.Empty;string[]? lineArray = null;while (!string.IsNullOrEmpty(currentLine = sr.ReadLine())){currentLine = currentLine.Trim();if (currentLine.Contains('"')){Regex regex = new Regex("\"(.*?)\"");MatchCollection matches = regex.Matches(currentLine);int offset = 0;foreach (Match match in matches.Cast<Match>()){Group group = match.Groups[1];if (group.Value.Contains(separator)){string replaceText = group.Value.Replace(separator, separatorTemp);currentLine = currentLine.Remove(group.Index + offset, group.Length);currentLine = currentLine.Insert(group.Index + offset, replaceText);offset = offset + replaceText.Length - group.Length;}}}lineArray = currentLine.Split(separator);lineArrayList.Add(lineArray);}}catch (Exception ex){// 异常处理...}finally{try { sr?.Close(); } catch { }try { fs?.Close(); } catch { }}return lineArrayList;
}

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

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

相关文章

【NLP练习】Transformer中的位置编码

&#x1f368; 本文为&#x1f517;365天深度学习训练营 中的学习记录博客&#x1f356; 原作者&#xff1a;K同学啊 一、什么是位置编码 1. 位置编码定义 Transformer 模型中的位置编码是为了在处理序列数据时引入位置信息&#xff0c;以便模型能够分辨输入序列中不同位置的词…

180.二叉树:二叉搜索树(力扣)

代码解决 /*** Definition for a binary tree node.* struct TreeNode {* int val;* TreeNode *left;* TreeNode *right;* TreeNode() : val(0), left(nullptr), right(nullptr) {}* TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}* Tre…

实时交通 | 城市交通态势采集及可视化操作(定时运行)

一、前言 交通态势数据是关于交通状况的一种量化描述&#xff0c;它提供了关于道路网络运行状态的详细信息。交通态势数据指的是根据车流入量和车流出量的定义&#xff0c;衡量整个全局交通区域交通态势的数据。这些数据通常从车辆GPS轨迹数据中提取&#xff0c;包括车辆行驶速…

Oracle备份失败处理,看这一篇就够了!

作者&#xff1a;IT邦德 中国DBA联盟(ACDU)成员&#xff0c;10余年DBA工作经验&#xff0c; Oracle、PostgreSQL ACE CSDN博客专家及B站知名UP主&#xff0c;全网粉丝10万 擅长主流Oracle、MySQL、PG、高斯及Greenplum备份恢复&#xff0c; 安装迁移&#xff0c;性能优化、故障…

时代巨兽!深度神经网络如何改变我们的世界?

深度神经网络 1、 简介1.1 定义深度神经网络1.2 深度学习的发展历程1.3 深度神经网络的应用领域 2、深度神经网络的基本原理2.1 神经元层2.1.1 神经元2.1.2 神经元层 2.2 前向传播2.3 反向传播2.4 激活函数2.4.1、作用2.4.2、常见激活函数2.4.3、选择激活函数的考虑 2.5 损失函…

Selenium+Pytest自动化测试框架能碰撞出什么样的火花

前言 selenium自动化 pytest测试框架 本章你需要 一定的python基础——至少明白类与对象&#xff0c;封装继承 一定的selenium基础——本篇不讲selenium&#xff0c;不会的可以自己去看selenium中文翻译网 一、测试框架简介 测试框架有什么优点呢&#xff1a; 代码复用率高…

网信办部署开展清朗专项行动,严打色情等违法信息外链

据网信中国官方公众号&#xff0c;近日&#xff0c;中央网信办专门印发通知&#xff0c;在全国范围内部署开展为期2个月的“清朗打击违法信息外链”专项行动。 据介绍&#xff0c;本次专项行动聚焦违法信息外链问题易发多发的8个重点环节开展整治。 一是账号环节。在账号头像…

零基础直接上手java跨平台桌面程序,使用javafx(五)TableView显示excel表

我们在窗口的中间加上TableVie&#xff1a; 在hello-view.fxml的文本中&#xff0c;要增加一些代码。在TableView定义中加上fx:id"TableView1"&#xff0c;这样java代码才方便访问&#xff0c;在java代码中要加上FXML private TableView TableView1;表示定义TableVie…

【ArcGISProSDK】OpenItemDialog打开文件对话框

打开单个文件 效果 代码 public async void OpenFunction() {// 获取默认数据库var gdbPath Project.Current.DefaultGeodatabasePath;OpenItemDialog openItemDialog new OpenItemDialog() { Title "打开要素文件",InitialLocation gdbPath,Filter ItemFilte…

vue 使用 ztree 超大量数据,前端树形结构展示

ztree 是一个很经典的基于jquey开发的树结构编辑展示UI组件库。 创建一个文件 ztree.vue&#xff0c;代码如下&#xff1a; <template><div><div class"ztree vue-giant-tree" :id"ztreeId"></div><div class"treeBox&q…

MySQL基础——函数和约束

目录 1函数 1.1字符串函数 1.2数值函数 1.3日期函数 1.4流程函数 2约束 2.1约束概述和演示 2.2外键约束&#xff08;表连接键&#xff09; 1函数 函数是指一段可以直接被另一段程序调用的程序或代码。 1.1字符串函数 MySQL中内置了很多字符串函数&#xff0c;常用的…

vue之一键部署的shell脚本和它的点.bat文件、海螺AI、ChatGPT

MENU 前言vite.config.ts的配置deploy文件夹的其他内容remote.shpwd.txtdeploy.bat 前言 1、在src同级新建deploy.bat文件&#xff1b; 2、在src同级新建deploy文件夹&#xff0c;文件夹中新建pwd.txt和remote.sh文件&#xff1b; 3、配置好后&#xff0c;直接双击deploy.bat文…

【计算机视觉】人脸算法之图像处理基础知识(五)

图像的几何变换 3.图像的旋转 图像的旋转就是让图像按照某一点旋转到指定的角度。需要确定3个参数&#xff1a;图像的旋转中心、旋转角度和缩放因子。在openv中通过getRotationMatrix2D()函数来实现图像的旋转。 import cv2 import numpy as npimgpath "images/img1.j…

Jacob环境探索(兼容性、管理员、DLL位置、VS环境,COM权限)

概述&#xff1a; 最近在生产开发实践出现了很多问题&#xff0c;经过了一系列排查&#xff0c;特做如下总结 探索成果&#xff1a; 1. jacob.dll的建议位置 首先jacob的官网&#xff0c;以及官方GitHub&#xff0c;你可以从这里找到DLL文件&#xff0c;以及相关资料然后DLL文…

缩窄route范围来提速本地打包的尝试

目录 为什么要缩窄route范围缩窄route的方式意外触发的重复构建重复构建的原因解决方案 为什么要缩窄route范围 对于一些大单页&#xff0c;单个router-view中可能包含上百个页面。但是开发的时候其实并不需要那么多调试那么多页面。 因此&#xff0c;为了节省不必要的打包和热…

CAPL通过addTimeToMeasurementStartTime或者getLocalTime获取本地时间

文章目录 getLocalTimeaddTimeToMeasurementStartTimegetLocalTime long tm[9]; getLocalTime(tm); // now tm contains the following entries: // tm[0] = 3; (seconds) // tm[1] = 51; (minutes) // tm[2] = 16; (hours)

计算机网络:网络层 - IP数据报的转发

计算机网络&#xff1a;网络层 - IP数据报的转发 基于终点转发最长前缀匹配二叉线索树路由表特殊路由特定主机路由默认路由 IP多播 基于终点转发 路由器转发报文时&#xff0c;是通过报文中的目的地址字段来转发的&#xff0c;也即是说路由器只知道终点的IP地址&#xff0c;根…

民生银行信用卡中心金融科技24届春招面经

本文介绍2024届春招中&#xff0c;中国民生银行下属信用卡中心的金融科技&#xff08;系统研发方向&#xff09; 岗位2场面试的基本情况、提问问题等。 2024年04月投递了中国民生银行下属信用卡中心的金融科技&#xff08;系统研发方向&#xff09; 岗位&#xff0c;暂时不清楚…

移动端消息中心,你未必会设计,发一些示例出来看看。

APP消息中心是一个用于管理和展示用户收到的各种消息和通知的功能模块。它在APP中的作用是提供一个集中管理和查看消息的界面&#xff0c;让用户能够方便地查看和处理各种消息。 以下是设计APP消息中心的一些建议&#xff1a; 1. 消息分类&#xff1a; 将消息按照不同的类型进…

关闭kylin(麒麟)系统的安全认证(烦人的安全认证)

打开grub sudo vim /etc/default/grup修改安全认证选项 增加12行&#xff0c;把13行注释掉 保存更改, 然后执行下面的命令&#xff1a; sudo sync sudo reboot重启成功后&#xff0c;就关闭了安全认证了~~~~~。 总体来讲&#xff0c;kylin还是基于ubuntu的内核的&#xff0c;…