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

相关文章

MySQL 8 中的一个强大功能 JSON_TABLE示例详解

《MySQL8中的一个强大功能JSON_TABLE示例详解》JSON_TABLE是MySQL8中引入的一个强大功能,它允许用户将JSON数据转换为关系表格式,从而可以更方便地在SQL查询中处理J... 目录基本语法示例示例查询解释应用场景不适用场景1. ‌jsON 数据结构过于复杂或动态变化‌2. ‌性能要

基于Python开发一个图像水印批量添加工具

《基于Python开发一个图像水印批量添加工具》在当今数字化内容爆炸式增长的时代,图像版权保护已成为创作者和企业的核心需求,本方案将详细介绍一个基于PythonPIL库的工业级图像水印解决方案,有需要... 目录一、系统架构设计1.1 整体处理流程1.2 类结构设计(扩展版本)二、核心算法深入解析2.1 自

C#连接SQL server数据库命令的基本步骤

《C#连接SQLserver数据库命令的基本步骤》文章讲解了连接SQLServer数据库的步骤,包括引入命名空间、构建连接字符串、使用SqlConnection和SqlCommand执行SQL操作,... 目录建议配合使用:如何下载和安装SQL server数据库-CSDN博客1. 引入必要的命名空间2.

Java中读取YAML文件配置信息常见问题及解决方法

《Java中读取YAML文件配置信息常见问题及解决方法》:本文主要介绍Java中读取YAML文件配置信息常见问题及解决方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要... 目录1 使用Spring Boot的@ConfigurationProperties2. 使用@Valu

Qt使用QSqlDatabase连接MySQL实现增删改查功能

《Qt使用QSqlDatabase连接MySQL实现增删改查功能》这篇文章主要为大家详细介绍了Qt如何使用QSqlDatabase连接MySQL实现增删改查功能,文中的示例代码讲解详细,感兴趣的小伙伴... 目录一、创建数据表二、连接mysql数据库三、封装成一个完整的轻量级 ORM 风格类3.1 表结构

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】分页结构体