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

相关文章

SpringBoot实现微信小程序支付功能

《SpringBoot实现微信小程序支付功能》小程序支付功能已成为众多应用的核心需求之一,本文主要介绍了SpringBoot实现微信小程序支付功能,文中通过示例代码介绍的非常详细,对大家的学习或者工作... 目录一、引言二、准备工作(一)微信支付商户平台配置(二)Spring Boot项目搭建(三)配置文件

Python获取C++中返回的char*字段的两种思路

《Python获取C++中返回的char*字段的两种思路》有时候需要获取C++函数中返回来的不定长的char*字符串,本文小编为大家找到了两种解决问题的思路,感兴趣的小伙伴可以跟随小编一起学习一下... 有时候需要获取C++函数中返回来的不定长的char*字符串,目前我找到两种解决问题的思路,具体实现如下:

在Android平台上实现消息推送功能

《在Android平台上实现消息推送功能》随着移动互联网应用的飞速发展,消息推送已成为移动应用中不可或缺的功能,在Android平台上,实现消息推送涉及到服务端的消息发送、客户端的消息接收、通知渠道(... 目录一、项目概述二、相关知识介绍2.1 消息推送的基本原理2.2 Firebase Cloud Me

Spring Boot项目中结合MyBatis实现MySQL的自动主从切换功能

《SpringBoot项目中结合MyBatis实现MySQL的自动主从切换功能》:本文主要介绍SpringBoot项目中结合MyBatis实现MySQL的自动主从切换功能,本文分步骤给大家介绍的... 目录原理解析1. mysql主从复制(Master-Slave Replication)2. 读写分离3.

Python通过模块化开发优化代码的技巧分享

《Python通过模块化开发优化代码的技巧分享》模块化开发就是把代码拆成一个个“零件”,该封装封装,该拆分拆分,下面小编就来和大家简单聊聊python如何用模块化开发进行代码优化吧... 目录什么是模块化开发如何拆分代码改进版:拆分成模块让模块更强大:使用 __init__.py你一定会遇到的问题模www.

Spring Security基于数据库的ABAC属性权限模型实战开发教程

《SpringSecurity基于数据库的ABAC属性权限模型实战开发教程》:本文主要介绍SpringSecurity基于数据库的ABAC属性权限模型实战开发教程,本文给大家介绍的非常详细,对大... 目录1. 前言2. 权限决策依据RBACABAC综合对比3. 数据库表结构说明4. 实战开始5. MyBA

Mybatis 传参与排序模糊查询功能实现

《Mybatis传参与排序模糊查询功能实现》:本文主要介绍Mybatis传参与排序模糊查询功能实现,本文通过实例代码给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧... 目录一、#{ }和${ }传参的区别二、排序三、like查询四、数据库连接池五、mysql 开发企业规范一、#{ }和${ }传参的

使用Python开发一个简单的本地图片服务器

《使用Python开发一个简单的本地图片服务器》本文介绍了如何结合wxPython构建的图形用户界面GUI和Python内建的Web服务器功能,在本地网络中搭建一个私人的,即开即用的网页相册,文中的示... 目录项目目标核心技术栈代码深度解析完整代码工作流程主要功能与优势潜在改进与思考运行结果总结你是否曾经

Win11安装PostgreSQL数据库的两种方式详细步骤

《Win11安装PostgreSQL数据库的两种方式详细步骤》PostgreSQL是备受业界青睐的关系型数据库,尤其是在地理空间和移动领域,:本文主要介绍Win11安装PostgreSQL数据库的... 目录一、exe文件安装 (推荐)下载安装包1. 选择操作系统2. 跳转到EDB(PostgreSQL 的

使用C#代码在PDF文档中添加、删除和替换图片

《使用C#代码在PDF文档中添加、删除和替换图片》在当今数字化文档处理场景中,动态操作PDF文档中的图像已成为企业级应用开发的核心需求之一,本文将介绍如何在.NET平台使用C#代码在PDF文档中添加、... 目录引言用C#添加图片到PDF文档用C#删除PDF文档中的图片用C#替换PDF文档中的图片引言在当