C#—csv文件格式操作实例【在winform表格中操作csv】
C#—csv文件格式操作实例【在winform表格中操作csv】
实例一
实例效果
当在winform界面中点击读取按钮时 将csv中的所有数据读取出来放置在datagridview控件,可以在datagridview控件中编辑数据,当点击保存按钮时 将datagridview控件中的所有数据存储在csv格式文件中。
第一步UI界面搭建

第二步封装一个csv文件格式的操作类
public class CSVAPI
{/// <summary>/// 保存/// </summary>/// <param name="date"></param>/// <param name="data"></param>/// <param name="result"></param>/// <param name="fileName"></param>public void SaveData(string date,string data, string result,string fileName){using (StreamWriter sw2 = new StreamWriter(fileName, true, Encoding.Default)){StringBuilder sb = new StringBuilder();sb.Append(date).Append(",").Append(data).Append(",").Append(result + "\n");sw2.Write(sb.ToString());}}/// <summary>/// 读取CSV/// </summary>/// <returns></returns>public string ReadData(string fileName){StreamReader sr = new StreamReader(fileName, Encoding.Default);string s = sr.ReadToEnd(); // 读取数据sr.Close();sr.Dispose();return s;}
}
第三步实现按钮事件
public partial class Form1 : Form
{public Form1(){InitializeComponent();}CSVAPI csv = new CSVAPI();string filename = "./data.csv";/// <summary>/// 保存/// </summary>/// <param name="sender"></param>/// <param name="e"></param>private void button1_Click(object sender, EventArgs e){if (dataGridView1.Rows.Count>0){// 写入表头(将表头写死)FileStream fs = new FileStream(filename, FileMode.Create, FileAccess.Write);StreamWriter sw = new StreamWriter(fs, Encoding.Default);StringBuilder sb = new StringBuilder(); // 定义可变字符串,保存存储的数据sb.Append("时间").Append(",").Append("姓名").Append(",").Append("事件");sw.WriteLine(sb);sw.Close();sw.Dispose();fs.Close();fs.Dispose();for (int i = 0; i < this.dataGridView1.RowCount-1; i++){csv.SaveData(this.dataGridView1.Rows[i].Cells[0].Value.ToString()+"", this.dataGridView1.Rows[i].Cells[1].Value.ToString() + "", this.dataGridView1.Rows[i].Cells[2].Value.ToString() + "", filename);}}}/// <summary>/// 读取/// </summary>/// <param name="sender"></param>/// <param name="e"></param>private void button2_Click(object sender, EventArgs e){this.dataGridView1.Rows.Clear();if (!File.Exists(filename)){MessageBox.Show("文件不存在");return;}string[] strings = csv.ReadData(filename).Split('\n');for (int i = 1;i < strings.Length;i++){if (!string.IsNullOrEmpty(strings[i])){string[] vals = strings[i].Split(',');this.dataGridView1.Rows.Add(vals);}}}
}
效果展示

实例二
实例效果
当在winform界面中点击读取按钮时弹出文件选择框,用户选择指定的csv文件然后将csv中的所有数据读取出来放置在datagridview控件,可以在datagridview控件中编辑数据,当点击保存按钮时 将datagridview控件中的所有数据存储在用户选择的csv格式文件路径中。
完整代码
public partial class Form1 : Form
{public Form1(){InitializeComponent();}OpenFileDialog ofd = new OpenFileDialog();//读取private void button1_Click(object sender, EventArgs e){//字符串-->dataTable--->dataSourceif(ofd.ShowDialog()==DialogResult.OK){FileStream fs = new FileStream(ofd.FileName, FileMode.Open);StreamReader sr = new StreamReader(fs,Encoding.Default);//读取文件流数据string data = "";//读出每一行的数据 "name ,age sex"string[] lines;// 数据的数组bool isHead = true; // 是否是表头DataTable dt = new DataTable();// 为了给datagridview设置数据源的类型while ((data=sr.ReadLine())!=null) //先赋值给data 再判断data是否为空 ,不为空时候 一直读取{lines= data.Split(','); //把每一行的数据使用逗号分隔 [name ,age ,sex]if(isHead) //是不是表头[name ,age ,sex] {//遍历表头数组 给每一列添加标题for(int i = 0; i < lines.Length; i++){dt.Columns.Add(lines[i]); //设置dt的列的数据源}isHead = false;}else //不是表头数据,每一行表格添加数据{DataRow d1 = dt.NewRow();// 指定datatable创建行for (int i = 0; i < lines.Length; i++){d1[i] = lines[i];// 单元格设置值}dt.Rows.Add(d1);}}//绑定数据源if (dt.Rows.Count==0) //如果没行的 证明没数据{MessageBox.Show("没有数据","温馨提示");}else{//证明有数据 展示到控件上//dataGridView1.DataSource = dt;// dataGridView1.ColumnCount 列的个数dataGridView1.ColumnCount = dt.Columns.Count;//设置表头for (int i = 0; i < dt.Columns.Count; i++){// dataGridView1.Columns[i].HeaderText 表格控件的每一列的标题dataGridView1.Columns[i].HeaderText = dt.Columns[i].ColumnName;}//设置行数据for (int i = 0; i < dt.Rows.Count; i++){//dataGridView1.Rows. 设置表格控件的所有的行dataGridView1.Rows.Add(dt.Rows[i].ItemArray);}}sr.Close();fs.Close();}}// 保存private void button2_Click(object sender, EventArgs e){//dataSource-->dataTable--->stringDataTable dt = new DataTable(); //创建dataTable类型//设置dt表头//遍历控件列的个数,根据控件的列的个数设置dt列for (int i = 0;i < dataGridView1.Columns.Count;i++){dt.Columns.Add(dataGridView1.Columns[i].HeaderText); //把控件列标题添加到dt列里面}//设置dt的行 for (int i = 0; i < dataGridView1.Rows.Count; i++) //遍历控件几行{DataRow row = dt.NewRow(); //创建行for (int j = 0; j < dataGridView1.Columns.Count; j++) //遍历控件几列{//dataGridView1[0,0] 根据几行几列取出表格数据row[j] = dataGridView1[j, i].Value;}dt.Rows.Add(row);}//把dt数据转成字符串进行写入SaveFileDialog sfd = new SaveFileDialog();sfd.Filter = "csv文件(*.csv)|.csv";if(sfd.ShowDialog()==DialogResult.OK){//开始写入FileStream fs = new FileStream(sfd.FileName, FileMode.Create);StreamWriter sw = new StreamWriter(fs,Encoding.Default);string data = "";// 写入的字符串//表头转成字符串for (int i = 0; i < dt.Columns.Count; i++){data += dt.Columns[i].ColumnName;// 把dt列标题取出拼接if(i <dt.Columns.Count-1){data += ","; // 列之间使用逗号隔开}}sw.WriteLine(data); //写入表头//写入行数据data = null;//防止表头数据重复写入for (int i = 0; i < dt.Rows.Count-1; i++){for (int j = 0; j <dt.Columns.Count; j++){data += dt.Rows[i][j]; //几行几列数据拼接dataif(j<dt.Columns.Count-1)//不是最后一列{data += ",";}}sw.WriteLine(data);//写入表数据data=null;}sw.Close();fs.Close();}}
}
1 datagridview 控件的常用属性
- dataGridView1.Columns 表格控件的所有列
- dataGridView1.Columns .Count 表格控件的所有列的个数
- dataGridView1.Rows 表格控件的所有行
- dataGridView1[0,0] 根据几行几列取出表格数据
- dataGridView1.Columns[i].HeaderTex 表格控件的列的文本内容
2 dataTable常用的属性和方法
- DataTable dt = new DataTable(); 创建dataTable类型
- DataRow row = dt.NewRow(); 创建一行
- dt.Rows.Add(row); 向dataTable添加一行
- dt.Columns.Add(); 向dataTable添加一列
- dt.Columns datatable所有的列
- dt.Rows datatable所有的行
- dt.Columns[i].ColumnName;列标题
相关文章:
C#—csv文件格式操作实例【在winform表格中操作csv】
C#—csv文件格式操作实例【在winform表格中操作csv】 实例一 实例效果 当在winform界面中点击读取按钮时 将csv中的所有数据读取出来放置在datagridview控件,可以在datagridview控件中编辑数据,当点击保存按钮时 将datagridview控件中的所有数据存储在…...
一周学会Flask3 Python Web开发-WTForms表单验证
锋哥原创的Flask3 Python Web开发 Flask3视频教程: 2025版 Flask3 Python web开发 视频教程(无废话版) 玩命更新中~_哔哩哔哩_bilibili 我们可以通过WTForms表单类属性的validators属性来实现表单验证。 常用的WTForms验证器 验证器说明DataRequired(messageNo…...
23种设计模式一览【设计模式】
文章目录 前言一、创建型模式(Creational Patterns)二、结构型模式(Structural Patterns)三、行为型模式(Behavioral Patterns) 前言 设计模式是软件工程中用来解决特定问题的一组解决方案。它们是经过验证…...
GPIO及其应用
GPIO及其应用 文章目录 GPIO及其应用1.GPIO概括2.GPIO工作基本结构3.GPIO寄存器3.1寄存器总览3.2寄存器功能3.3BIT简写的代表 4.GPIO的电气特性4.1拉电流与灌电流4.2驱动大功率负载4.3电平逻辑兼容性 5.LED闪烁(实操)6.LED交替闪烁(实操)7.开关控制LED灯…...
NO1.C++语言基础|四种智能指针|内存分配情况|指针传擦和引用传参|const和static|c和c++的区别
1. 说⼀下你理解的 C 中的四种智能指针 智能指针的作用是管理指针,可以避免内存泄漏的发生。 智能指针就是一个类,当超出了类的作用域时,就会调用析构函数,这时就会自动释放资源。 所以智能指针作用的原理就是在函数结束时自动释…...
Vue 关于如何在vue中实现跨域请求问题
📚首先,让我们了解一下什么是跨域。当一个请求的URL的协议、域名、端口三者中任意一个与当前页面的URL不同,就称为跨域请求。 🔒为什么会出现跨域问题呢?这是因为浏览器的同源策略限制。同源策略是浏览器最核心的安全…...
毕业项目推荐:基于yolov8/yolov5/yolo11的暴力行为检测识别系统(python+卷积神经网络)
文章目录 概要一、整体资源介绍技术要点功能展示:功能1 支持单张图片识别功能2 支持遍历文件夹识别功能3 支持识别视频文件功能4 支持摄像头识别功能5 支持结果文件导出(xls格式)功能6 支持切换检测到的目标查看 二、数据集三、算法介绍1. YO…...
算法随笔_64: 含特定字母的最小子序列
上一篇:算法随笔_63: 子数组范围和-CSDN博客 题目描述如下: 给你一个字符串 s ,一个整数 k ,一个字母 letter 以及另一个整数 repetition 。 返回 s 中长度为 k 且 字典序最小 的子序列,该子序列同时应满足字母 letter 出现 至少 repetitio…...
red hat系统离线部署Deepseek
一个人在单位离线部署踩了不少坑,记录一下 模型准备 1.huggingface下载gguf文件,将文件放到相应目录(例如E:/AI文件夹) 2.在文件夹内用文本建一个文件,命名Modelfile(删除txt后缀) 3.用文本编辑器打开Modelfile,在文本内输入 fr…...
torch.einsum 的 10 个常见用法详解以及多头注意力实现
torch.einsum 是 PyTorch 提供的一个高效的张量运算函数,能够用紧凑的 Einstein Summation 约定(Einstein Summation Convention, Einsum)描述复杂的张量操作,例如矩阵乘法、转置、内积、外积、批量矩阵乘法等。 1. 基本语法 tor…...
【DeepSeek】一文详解GRPO算法——为什么能减少大模型训练资源?
GRPO,一种新的强化学习方法,是DeepSeek R1使用到的训练方法。 今天的这篇博客文章,笔者会从零开始,层层递进地为各位介绍一种在强化学习中极具实用价值的技术——GRPO(Group Relative Policy Optimization)…...
C++基础系列【19】运算符重载
博主介绍:程序喵大人 35- 资深C/C/Rust/Android/iOS客户端开发10年大厂工作经验嵌入式/人工智能/自动驾驶/音视频/游戏开发入门级选手《C20高级编程》《C23高级编程》等多本书籍著译者更多原创精品文章,首发gzh,见文末👇…...
大数据环境(单机版) Flume传输数据到Kafka
文章目录 前言一、准备二、安装三、配置环境变量四、修改配置4.1、kafka配置4.2、Flume配置 五、启动程序5.1、启动zk5.2、启动kafka5.3、启动flume 六、测试6.1、启动一个kafka终端,用来消费消息6.2、写入日志 其他 前言 flume监控指定目录,传输数据到…...
Ollama 框架本地部署教程:开源定制,为AI 项目打造专属解决方案!
Ollama 是一款开源的本地大语言模型(LLM)运行框架,用于管理和运行语言模型。具有以下核心特点: 开源可定制:采用 MIT 开源协议,开发者能自由使用、阅读源码并定制,可根据自身需求进行功能扩展和…...
开发环境搭建-03.后端环境搭建-使用Git进行版本控制
一.Git进行版本控制 我们对项目开发就会产生很多代码,我们需要有效的将这些代码管理起来,因此我们真正开发代码前需要把我们的Git环境搭建好。通过Git来管理我们项目的版本,进而实现版本控制。 首先我们使用Git创建本地仓库,然后…...
[Lc(2)滑动窗口_1] 长度最小的数组 | 无重复字符的最长子串 | 最大连续1的个数 III | 将 x 减到 0 的最小操作数
目录 1. 长度最小的字数组 题解 代码 ⭕2.无重复字符的最长子串 题解 代码 3.最大连续1的个数 III 题解 代码 4.将 x 减到 0 的最小操作数 题解 代码 1. 长度最小的字数组 题目链接:209.长度最小的字数组 题目分析: 给定一个含有 n 个 正整数 的数组…...
互联网时代如何保证数字足迹的安全,以防个人信息泄露?
用户在网络上所做的几乎所有事情,包括浏览、社交媒体活动、搜索查询、在线订阅,甚至购物,都会留下一条数据线索,这些数据可用于创建用户在线身份的详细档案。如果这些信息暴露,恶意行为者可能会利用它们将用户置于各种…...
海康摄像头接入流媒体服务器实现https域名代理播放
环境 操作系统:Ubuntu 22.04流媒体服务器:srs 官网安装教程srs开启GB28181协议 官网开启教程进行海康摄像头的配置 官网配置教程srs使用systemctl实现开机自启 官网配置教程 nginx配置说明 server {listen 80;server_name a.com;return 301 https://$…...
【C++设计模式】第五篇:原型模式(Prototype)
注意:复现代码时,确保 VS2022 使用 C17/20 标准以支持现代特性。 克隆对象的效率革命 1. 模式定义与用途 核心思想 原型模式:通过复制现有对象(原型)来创建新对象,而非通过new构造。关键用…...
51单片机课综合项目
1、按键控制蜂鸣器实验 1、实验现象:下载程序后,按下K1键蜂鸣器发声一次,按下K2键,蜂鸣器连续发声,再次按下K2键,发声取消 2、使用到的外设模块:蜂鸣器模块beep 独立按键模块 key 3、编程框架(…...
【最大半连通子图——tarjan求最大连通分量,拓扑排序,树形DP】
题目 分析 最大连通分量肯定是满足半连通分量的要求,因此tarjan。 同时为了简化图,我们进行缩点,图一定变为拓扑图。 我们很容易看出,只要是一条不分叉的链,是满足条件的。 于是我们按照拓扑序不断树形DP 建边注意…...
一周学会Flask3 Python Web开发-在模板中渲染WTForms表单视图函数里获取表单数据
锋哥原创的Flask3 Python Web开发 Flask3视频教程: 2025版 Flask3 Python web开发 视频教程(无废话版) 玩命更新中~_哔哩哔哩_bilibili 为了能够在模板中渲染表单,我们需要把表单类实例传入模板。首先在视图函数里实例化表单类LoginForm,然…...
DeepSeek R1助力,腾讯AI代码助手解锁音乐创作新
目录 1. DeepSeekR1模型简介2. 歌词创作流程2.1 准备工作2.2 歌词生成技巧 3. 音乐制作环节3.1 主流AI音乐生成平台 4. 歌曲欣赏5. 总结展望 1. DeepSeekR1模型简介 腾讯AI代码助手最新推出的DeepSeekR1模型不仅在代码生成方面表现出色,其强大的自然语言处理能力也…...
用户空间与内核空间切换机制详解
用户空间与内核空间切换机制详解 一、切换触发条件 用户态与内核态的切换由以下三类事件触发: 系统调用 用户程序主动通过int 0x80(x86)或ecall(RISC-V)等指令发起系统调用,请求内核服务(如文件读写、进程创建等)。此时CPU自动进入内核态处理请求,完成后返回用户…...
【微信小程序】每日心情笔记
个人团队的比赛项目,仅供学习交流使用 一、项目基本介绍 1. 项目简介 一款基于微信小程序的轻量化笔记工具,旨在帮助用户通过记录每日心情和事件,更好地管理情绪和生活。用户可以根据日期和心情分类(如开心、平静、难过等&#…...
为AI聊天工具添加一个知识系统 之135 详细设计之76 通用编程语言 之6
本文要点 要点 通用编程语言设计 本设计通过三级符号系统的动态映射与静态验证的有机结合,实现了从文化表达到硬件优化的全链路支持。每个设计决策均可在[用户原始讨论]中找到对应依据,包括: 三级冒号语法 → 提升文化符号可读性圣灵三角…...
前端基础之组件
组件:实现应用中局部功能代码和资源的集合 非单文件组件 <!DOCTYPE html> <html lang"en"> <head> <meta charset"UTF-8"> <meta name"viewport" content"widthdevice-width, initial-scale1.0"…...
spring boot整合flyway实现数据的动态维护
1、简单介绍一下flyway Flyway 是一款开源的数据库版本控制工具,主要用于管理数据库结构的变更(如创建表、修改字段、插入数据等)。它通过跟踪和执行版本化的迁移脚本,帮助团队实现数据库变更的自动化。接下来简单介绍一下flyway…...
通往 AI 之路:Python 机器学习入门-线性代数
2.1 线性代数(机器学习的核心) 线性代数是机器学习的基础之一,许多核心算法都依赖矩阵运算。本章将介绍线性代数中的基本概念,包括标量、向量、矩阵、矩阵运算、特征值与特征向量,以及奇异值分解(SVD&…...
Matlab中的均值函数mean
今天调了一个代码里的bug,根源居然是mean函数的使用细节没留意到~ 具体来说,写一个类似k均值聚类那样的程序,交替迭代,其中有一部是使用mean求一堆向量的均值,这些向量存在一个矩阵里,每行对应一个向量。若…...
