C#开发小试手----小功能:C#读取csv文件——针对两种不同需求的表头

本文主要是介绍C#开发小试手----小功能:C#读取csv文件——针对两种不同需求的表头,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在练习过程中先后遇到了以下两种需求:

  1. 完整读取CSV文件,包括CSV文件的表头
  2. 只读取CSV文件内容,表头自定义添加

针对需求1,代码如下:

//*********************************csv2dt----读取csv表头方案**********************************************************/// <summary>  /// 将Csv读入DataTable  /// </summary>  /// <param name="filePath">csv文件路径</param>  /// <param name="n">表示第n行是字段title,第n+1行是记录开始</param>  /// <param name="k">可选参数表示最后K行不算记录默认0</param>  
public static DataTable csv2dt(string filePath, int n) //这个dt 是个空白的没有任何行列的DataTable  {String csvSplitBy = "(?<=^|,)(\"(?:[^\"]|\"\")*\"|[^,]*)";StreamReader reader = new StreamReader(filePath, System.Text.Encoding.Default, false);int i = 0, m = 0;reader.Peek();DataTable dt = new DataTable();while (reader.Peek() > 0){m = m + 1;string str = reader.ReadLine();if (m >= n ){if (m == n ) //如果是字段行,则自动加入字段。  {MatchCollection mcs = Regex.Matches(str, csvSplitBy);foreach (Match mc in mcs){dt.Columns.Add(mc.Value); //增加列标题  }}else{MatchCollection mcs = Regex.Matches(str, "(?<=^|,)(\"(?:[^\"]|\"\")*\"|[^,]*)");//正则表达式判断i = 0;System.Data.DataRow dr = dt.NewRow();foreach (Match mc in mcs){dr[i] = mc.Value;//dr[i] = mc.Value.Replace("\"", "");//数列字符串自带的引号i++;}dt.Rows.Add(dr);  //DataTable 增加一行       }}}return dt;}private void button1_Click(object sender, EventArgs e)//打开文件并传入ArrayList,此处不可以写返回,返回会报错{string str_filePath = Form1.OpenFile();//打开文件if (str_filePath != "")//判断来的字符串是否为“”,因为在选择文件时如果点击取消,则会返回str="",测试过用!=null来判断,但会报错;{DataTable dt = Form1.csv2dt(@str_filePath, 1);dataGridView1.DataSource = dt;//datatable数据显示}}

针对需求2,代码如下:

//*********************************csv2dt----自定义表头方案*********************************************public static DataTable CreateDataTableHead(String[] str_DataTableHead)//创建一个空表,并建立表头{DataTable dt = new DataTable();for (int i = 0; i < str_DataTableHead.Length; i++){dt.Columns.Add(str_DataTableHead[i]);}//遍历字段名作为表头return dt;}/// <summary>  /// 将Csv读入DataTable  /// </summary>  /// <param name="filePath">csv文件路径</param>  /// <param name="n">表示第n行是字段title,第n+1行是记录开始</param>  /// <param name="k">可选参数表示最后K行不算记录默认0</param>  public static DataTable csv2dt(string filePath, int n, DataTable dt) //这个dt 是个空白的没有任何行列的DataTable  {String csvSplitBy = "(?<=^|,)(\"(?:[^\"]|\"\")*\"|[^,]*)";StreamReader reader = new StreamReader(filePath, System.Text.Encoding.Default, false);int i = 0, m = 0;reader.Peek();while (reader.Peek() > 0){m = m + 1;string str = reader.ReadLine();if (m >= n + 1){if (m == n) //如果是字段行,则自动加入字段。  {MatchCollection mcs = Regex.Matches(str, csvSplitBy);foreach (Match mc in mcs){dt.Columns.Add(mc.Value); //增加列标题  }}else{MatchCollection mcs = Regex.Matches(str, "(?<=^|,)(\"(?:[^\"]|\"\")*\"|[^,]*)");i = 0;System.Data.DataRow dr = dt.NewRow();foreach (Match mc in mcs){dr[i] = mc.Value.Replace("\"", "");//数列字符串自带的引号i++;}dt.Rows.Add(dr);  //DataTable 增加一行       }}}return dt;}private void btn_inputFileForm_daogui1_Click(object sender, EventArgs e)//导入参数文件{string str_filePath = daogui.OpenFile();//打开文件if (str_filePath != "")//判断来的字符串是否为“”,因为在选择文件时如果点击取消,则会返回str="",测试过用!=null来判断,但会报错;{String[] str_DataTableHead_daogui1 = { "A", "B", "C", "D" };DataTable dt_TableHead_daogui1 = daogui.CreateDataTableHead(str_DataTableHead_daogui1);daogui1_Para_dt = daogui.csv2dt(@str_filePath, 1, dt_TableHead_daogui1);//csv数据转换进入DataTableListOfPara listofpara = new ListOfPara();listofpara.biaoshi_label_para.Text = "导轨";//此句与本功能无关,方便后面调用,做一标识listofpara.Show();listofpara.dataGridView_ListOfPara.DataSource = daogui1_Para_dt;//datatable数据显示listofpara.dataGridView_ListOfPara.ClearSelection();}}
需求2相较于需求1,多了一个CreateDataTableHead方法,同时改变了CSV2dt方法中的参数取值范围,即可实现

这篇关于C#开发小试手----小功能:C#读取csv文件——针对两种不同需求的表头的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/748933

相关文章

C#读写文本文件的多种方式详解

《C#读写文本文件的多种方式详解》这篇文章主要为大家详细介绍了C#中各种常用的文件读写方式,包括文本文件,二进制文件、CSV文件、JSON文件等,有需要的小伙伴可以参考一下... 目录一、文本文件读写1. 使用 File 类的静态方法2. 使用 StreamReader 和 StreamWriter二、二进

C#中Guid类使用小结

《C#中Guid类使用小结》本文主要介绍了C#中Guid类用于生成和操作128位的唯一标识符,用于数据库主键及分布式系统,支持通过NewGuid、Parse等方法生成,感兴趣的可以了解一下... 目录前言一、什么是 Guid二、生成 Guid1. 使用 Guid.NewGuid() 方法2. 从字符串创建

C# 比较两个list 之间元素差异的常用方法

《C#比较两个list之间元素差异的常用方法》:本文主要介绍C#比较两个list之间元素差异,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录1. 使用Except方法2. 使用Except的逆操作3. 使用LINQ的Join,GroupJoin

mysql表操作与查询功能详解

《mysql表操作与查询功能详解》本文系统讲解MySQL表操作与查询,涵盖创建、修改、复制表语法,基本查询结构及WHERE、GROUPBY等子句,本文结合实例代码给大家介绍的非常详细,感兴趣的朋友跟随... 目录01.表的操作1.1表操作概览1.2创建表1.3修改表1.4复制表02.基本查询操作2.1 SE

Golang如何用gorm实现分页的功能

《Golang如何用gorm实现分页的功能》:本文主要介绍Golang如何用gorm实现分页的功能方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录背景go库下载初始化数据【1】建表【2】插入数据【3】查看数据4、代码示例【1】gorm结构体定义【2】分页结构体

SpringBoot开发中十大常见陷阱深度解析与避坑指南

《SpringBoot开发中十大常见陷阱深度解析与避坑指南》在SpringBoot的开发过程中,即使是经验丰富的开发者也难免会遇到各种棘手的问题,本文将针对SpringBoot开发中十大常见的“坑... 目录引言一、配置总出错?是不是同时用了.properties和.yml?二、换个位置配置就失效?搞清楚加

Java Web实现类似Excel表格锁定功能实战教程

《JavaWeb实现类似Excel表格锁定功能实战教程》本文将详细介绍通过创建特定div元素并利用CSS布局和JavaScript事件监听来实现类似Excel的锁定行和列效果的方法,感兴趣的朋友跟随... 目录1. 模拟Excel表格锁定功能2. 创建3个div元素实现表格锁定2.1 div元素布局设计2.

Python中对FFmpeg封装开发库FFmpy详解

《Python中对FFmpeg封装开发库FFmpy详解》:本文主要介绍Python中对FFmpeg封装开发库FFmpy,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录一、FFmpy简介与安装1.1 FFmpy概述1.2 安装方法二、FFmpy核心类与方法2.1 FF

k8s上运行的mysql、mariadb数据库的备份记录(支持x86和arm两种架构)

《k8s上运行的mysql、mariadb数据库的备份记录(支持x86和arm两种架构)》本文记录在K8s上运行的MySQL/MariaDB备份方案,通过工具容器执行mysqldump,结合定时任务实... 目录前言一、获取需要备份的数据库的信息二、备份步骤1.准备工作(X86)1.准备工作(arm)2.手

HTML5实现的移动端购物车自动结算功能示例代码

《HTML5实现的移动端购物车自动结算功能示例代码》本文介绍HTML5实现移动端购物车自动结算,通过WebStorage、事件监听、DOM操作等技术,确保实时更新与数据同步,优化性能及无障碍性,提升用... 目录1. 移动端购物车自动结算概述2. 数据存储与状态保存机制2.1 浏览器端的数据存储方式2.1.