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

相关文章

这15个Vue指令,让你的项目开发爽到爆

1. V-Hotkey 仓库地址: github.com/Dafrok/v-ho… Demo: 戳这里 https://dafrok.github.io/v-hotkey 安装: npm install --save v-hotkey 这个指令可以给组件绑定一个或多个快捷键。你想要通过按下 Escape 键后隐藏某个组件,按住 Control 和回车键再显示它吗?小菜一碟: <template

Hadoop企业开发案例调优场景

需求 (1)需求:从1G数据中,统计每个单词出现次数。服务器3台,每台配置4G内存,4核CPU,4线程。 (2)需求分析: 1G / 128m = 8个MapTask;1个ReduceTask;1个mrAppMaster 平均每个节点运行10个 / 3台 ≈ 3个任务(4    3    3) HDFS参数调优 (1)修改:hadoop-env.sh export HDFS_NAMENOD

2. c#从不同cs的文件调用函数

1.文件目录如下: 2. Program.cs文件的主函数如下 using System;using System.Collections.Generic;using System.Linq;using System.Threading.Tasks;using System.Windows.Forms;namespace datasAnalysis{internal static

嵌入式QT开发:构建高效智能的嵌入式系统

摘要: 本文深入探讨了嵌入式 QT 相关的各个方面。从 QT 框架的基础架构和核心概念出发,详细阐述了其在嵌入式环境中的优势与特点。文中分析了嵌入式 QT 的开发环境搭建过程,包括交叉编译工具链的配置等关键步骤。进一步探讨了嵌入式 QT 的界面设计与开发,涵盖了从基本控件的使用到复杂界面布局的构建。同时也深入研究了信号与槽机制在嵌入式系统中的应用,以及嵌入式 QT 与硬件设备的交互,包括输入输出设

OpenHarmony鸿蒙开发( Beta5.0)无感配网详解

1、简介 无感配网是指在设备联网过程中无需输入热点相关账号信息,即可快速实现设备配网,是一种兼顾高效性、可靠性和安全性的配网方式。 2、配网原理 2.1 通信原理 手机和智能设备之间的信息传递,利用特有的NAN协议实现。利用手机和智能设备之间的WiFi 感知订阅、发布能力,实现了数字管家应用和设备之间的发现。在完成设备间的认证和响应后,即可发送相关配网数据。同时还支持与常规Sof

C++11第三弹:lambda表达式 | 新的类功能 | 模板的可变参数

🌈个人主页: 南桥几晴秋 🌈C++专栏: 南桥谈C++ 🌈C语言专栏: C语言学习系列 🌈Linux学习专栏: 南桥谈Linux 🌈数据结构学习专栏: 数据结构杂谈 🌈数据库学习专栏: 南桥谈MySQL 🌈Qt学习专栏: 南桥谈Qt 🌈菜鸡代码练习: 练习随想记录 🌈git学习: 南桥谈Git 🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈�

【Prometheus】PromQL向量匹配实现不同标签的向量数据进行运算

✨✨ 欢迎大家来到景天科技苑✨✨ 🎈🎈 养成好习惯,先赞后看哦~🎈🎈 🏆 作者简介:景天科技苑 🏆《头衔》:大厂架构师,华为云开发者社区专家博主,阿里云开发者社区专家博主,CSDN全栈领域优质创作者,掘金优秀博主,51CTO博客专家等。 🏆《博客》:Python全栈,前后端开发,小程序开发,人工智能,js逆向,App逆向,网络系统安全,数据分析,Django,fastapi

活用c4d官方开发文档查询代码

当你问AI助手比如豆包,如何用python禁止掉xpresso标签时候,它会提示到 这时候要用到两个东西。https://developers.maxon.net/论坛搜索和开发文档 比如这里我就在官方找到正确的id描述 然后我就把参数标签换过来

让树莓派智能语音助手实现定时提醒功能

最初的时候是想直接在rasa 的chatbot上实现,因为rasa本身是带有remindschedule模块的。不过经过一番折腾后,忽然发现,chatbot上实现的定时,语音助手不一定会有响应。因为,我目前语音助手的代码设置了长时间无应答会结束对话,这样一来,chatbot定时提醒的触发就不会被语音助手获悉。那怎么让语音助手也具有定时提醒功能呢? 我最后选择的方法是用threading.Time

C#实战|大乐透选号器[6]:实现实时显示已选择的红蓝球数量

哈喽,你好啊,我是雷工。 关于大乐透选号器在前面已经记录了5篇笔记,这是第6篇; 接下来实现实时显示当前选中红球数量,蓝球数量; 以下为练习笔记。 01 效果演示 当选择和取消选择红球或蓝球时,在对应的位置显示实时已选择的红球、蓝球的数量; 02 标签名称 分别设置Label标签名称为:lblRedCount、lblBlueCount