WinForms 零基础进阶教程:文件操作与 CSV 处理

2024-04-15 13:28

本文主要是介绍WinForms 零基础进阶教程:文件操作与 CSV 处理,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

    • 文件操作
      • 数据存储与文件操作
      • 文件存取的好处
      • 文件存取的方式
      • 文本文件的写入和读取
      • 文本文件的删除、复制和移动
    • 目录的操作
      • 文件属性操作
      • 文件路径
    • 对话框
      • OpenFileDialog对话框
      • SaveFileDialog对话框
      • 对话框中CheckPathExists属性的应用
    • CSV 文件读写与 DataGridView 进阶
      • DataGridView主要属性:
      • DataSource
      • 行(Row 相关属性)
      • 列(Column 相关属性)
      • CSV(Comma Separated Values 逗号分隔值)
      • CSV文件格式
      • CSV 文件格式
      • CSV 文件读写简易版本
    • 实践练习:实现登录注册功能
      • 注册功能
      • 登录功能
    • 总结

文件操作

数据存储与文件操作

在软件开发中,数据存储是核心功能之一。数据存储的方式主要分为数据库存储和文件存储。

  • 数据库存储:适合大量、且关系复杂并有序的数据存取。
  • 文件存取:适合大量、数据关系简单的数据存取,如系统的日志文件等。

文件存取的好处

  • 读取操作方便:文件存储的数据可以直接通过文件系统进行读取。
  • 存储介质灵活:文件可以存储在任何介质中,如硬盘、U盘、网络等。

文件存取的方式

  • 文本文件的写入和读取:通过流的方式进行数据的存取。
  • 二进制文件的写入和读取:适用于存储图像、音频、视频等非文本数据。

文本文件的写入和读取

private void button1_Click(object sender, EventArgs e)
{//1.创建一个文件流FileStream fs = new FileStream(@"myfile.txt", FileMode.Create);//2.创建写入器StreamWriter sw = new StreamWriter(fs);//3.以流的方式写入数据sw.Write(this.textBox1.Text.Trim());//4.关闭写入器sw.Close();//5.关闭文件流fs.Close();
}

文本文件的删除、复制和移动

文本文件的删除、复制和移动是文件操作中的常见需求。例如,在软件的在线升级或下载文件时,通常会先将文件保存到临时文件夹中,确认无误后再进行相应的操作。

//删除文件
//删除文件private void button4_Click(object sender, EventArgs e){File.Delete(this.textBox2.Text);}//复制文件private void button5_Click(object sender, EventArgs e){//首先判断路径文件是否存在if (File.Exists(this.textBox2.Text)){//Ctrl+CFile.Copy(this.textBox2.Text, this.textBox3.Text);}}//移动文件private void button6_Click(object sender, EventArgs e){//Ctrl + XFile.Move(this.textBox2.Text, this.textBox3.Text);}

目录的操作

目录操作包括创建、删除、列出目录内容等。

//显示指定目录下所有的文件//显示指定目录下所有的文件private void button7_Click(object sender, EventArgs e){string [] files=   Directory.GetFiles(@"E:\0408_文件操作\01_目录和文件的操作");//this.textBox1.Text = "";this.textBox1.Clear();foreach (string file in files) {this.textBox1.Text+= file+"\r\n";}}//显示指定目录下的所有子目录private void button8_Click(object sender, EventArgs e){//目录下的子目录//string[] dirs= Directory.GetDirectories(@"E:\0408_文件操作\01_目录和文件的操作"); this.textBox1.Text = "";//this.textBox1.Clear();//foreach (string dir in dirs) {//    this.textBox1.Text += dir + "\r\n";//}//目录下的所有子目录(包括子目录的目录)//递归: 函数自己调用自己(要有终止条件,没有终止条件就是死循环)this.textBox1.Clear();GetAllsubDit(@"E:\0408_文件操作\01_目录和文件的操作");}private void GetAllsubDit(string path){string[] dirs = Directory.GetDirectories(path);foreach (string dir in dirs){//判断当前目录是否还有子目录,如果还有子目录,需要再次进行函数的调用//注意这里的Path不是参数path,而是Path类(路径类)if (Path.GetDirectoryName(dir).Length>0){GetAllsubDit(dir);}this.textBox1.Text += dir + "\r\n";}}//在指定目录下创建一个子目录private void button9_Click(object sender, EventArgs e){Directory.CreateDirectory(@"吴凡");}//删除指定目录下的所有的子目录和文件private void button10_Click(object sender, EventArgs e){//删除 只能删除空目录//Directory.Delete(@"吴凡");//使用DirectoryInfo的实例对象调用Delete方法并设置参数为true,可以删除非空目录DirectoryInfo dir =  new DirectoryInfo(@"吴凡");dir.Delete(true);}

文件属性操作

通过File类和FileInfo类可以操作文件的属性,如设置文件为只读或隐藏。
FileInfo使用|表示设置多个属性
例如 fi.Attributes=FileAttributes.Archive | FileAttributes.ReadOnly

			//只读  ReadOnly  和 隐藏 Hidden//获取文件的属性Console.WriteLine(File.GetAttributes(@"C:\OneDriveTemp"));//设置文件的属性File.SetAttributes(@"C:\吴凡", FileAttributes.ReadOnly);FileInfo fi = new FileInfo(@"C:\吴凡");// Console.WriteLine(fi.Attributes.ToString());//设置fi.Attributes = FileAttributes.ReadOnly;fi.Attributes = FileAttributes.Archive;//使用 | 设置多个属性//只读属性和系统属性,删除的时候会拒绝访问fi.Attributes = FileAttributes.Archive | FileAttributes.ReadOnly;Console.WriteLine(fi.Attributes.ToString());

文件路径

文件路径的操作方法主要在Path类中实现,同时也可以使用Environment类获取环境变量相关的路径信息。
相对路径:不完整的路径,相对于当前项目的bin\Debug文件夹
绝对路径:完整的路径,从盘符开始

string dirPath = @"C:\Users\12015\Desktop\C#工业软件开发文档";string filePath = @"C:\Users\12015\Desktop\C#工业软件开发文档\打开项目\1.png";//获取当前路径Console.WriteLine(Environment.CurrentDirectory);Console.WriteLine("----------------------");//获取文件后缀Console.WriteLine(Path.GetExtension(filePath));//获取文件或者文件夹的名字Console.WriteLine(Path.GetFileName(dirPath));Console.WriteLine(Path.GetFileName(filePath));//获取绝对路径Console.WriteLine(Path.GetFullPath(dirPath));Console.WriteLine(Path.GetFullPath(filePath));Console.WriteLine(Path.GetFullPath(@"1.txt"));//更改文件后缀(改扩展名并不影响实际文件系统上的文件类型或内容)Console.WriteLine(Path.ChangeExtension(filePath,"jpg"));//生成路径Console.WriteLine(Path.Combine(new string[] { @"C:\", "Users", "12015" }));//获取根路径Console.WriteLine(Path.GetPathRoot(filePath));//随机生成文件或者文件名Console.WriteLine(Path.GetRandomFileName());//----------------------了解-----------------//获取文件名中的无效字符Console.WriteLine(Path.GetInvalidFileNameChars());//获取路径中的无效字符Console.WriteLine(Path.GetInvalidPathChars());//获取当前系统临时文件夹的路径Console.WriteLine(Path.GetTempPath());Console.WriteLine(Path.GetTempFileName());//..............

对话框

文件对话框是与用户交互的重要组件,常用于打开或保存文件。
常用属性表:

属性名功能说明
InitialDirectory对话框的初始目录
Filter文件筛选器,按"显示名称|类型"格式编写 例如,“文本文件(.txt)|.txt|所有文件(.)||.
FileName选取的文件的路径
Title将显示在对话框标题栏中的字符
RestoreDirectory指示对话框在关闭前是否还原当前目录。
CheckPathExists在对话框返回之前,检查指定路径是否存在

OpenFileDialog对话框

//打开文件对话框openFileDialog1.InitialDirectory = @"E:\";openFileDialog1.Filter = "文本文件|*.txt";openFileDialog1.Title = "选择txt文件";if (this.openFileDialog1.ShowDialog()==DialogResult.OK){//openFileDialog1.FileName;FileStream fs = new FileStream(openFileDialog1.FileName, FileMode.Open);StreamReader sr = new StreamReader(fs, Encoding.UTF8);this.textBox1.Text = sr.ReadToEnd();sr.Close();fs.Close();}

SaveFileDialog对话框

			saveFileDialog1.InitialDirectory = @"E:\";saveFileDialog1.Filter = "文本文件|*.txt";saveFileDialog1.Title = "另存为txt文件";if (this.saveFileDialog1.ShowDialog() == DialogResult.OK){FileStream fs = new FileStream(saveFileDialog1.FileName, FileMode.Create);StreamWriter sw = new StreamWriter(fs);sw.Write(this.textBox1.Text.Trim());sw.Close();fs.Close();}

对话框中CheckPathExists属性的应用

CheckPathExists 属性通常出现在与文件选择相关的对话框组件中,如 Windows Forms 中的 OpenFileDialog 或 SaveFileDialog。这个属性用于控制当用户在对话框中指定一个不存在的文件或目录路径时,对话框是否应该显示警告。启用此属性可以增强用户的交互体验,防止他们在尝试打开或保存文件时因路径无效而导致操作失败

示例

对于 OpenFileDialog:

using System;
using System.Windows.Forms;public partial class YourForm : Form
{public YourForm(){InitializeComponent();}private void btnOpenFile_Click(object sender, EventArgs e){using (OpenFileDialog openFileDialog = new OpenFileDialog()){// 设置 CheckPathExists 属性openFileDialog.CheckPathExists = true;// 其他对话框设置,如 Filter、Title 等openFileDialog.Filter = "Text Files (*.txt)|*.txt|All Files (*.*)|*.*";openFileDialog.Title = "Open Text File";if (openFileDialog.ShowDialog(this) == DialogResult.OK){string filePath = openFileDialog.FileName;// 在这里处理选中的文件Console.WriteLine($"Selected file: {filePath}");}}}
}

对于 SaveFileDialog:

using System;
using System.Windows.Forms;public partial class YourForm : Form
{public YourForm(){InitializeComponent();}private void btnSaveFile_Click(object sender, EventArgs e){using (SaveFileDialog saveFileDialog = new SaveFileDialog()){// 设置 CheckPathExists 属性saveFileDialog.CheckPathExists = true;// 其他对话框设置,如 Filter、Title、OverwritePrompt 等saveFileDialog.Filter = "Text Files (*.txt)|*.txt|All Files (*.*)|*.*";saveFileDialog.Title = "Save Text File";saveFileDialog.OverwritePrompt = true;if (saveFileDialog.ShowDialog(this) == DialogResult.OK){string filePath = saveFileDialog.FileName;// 在这里处理保存文件的操作Console.WriteLine($"Saving file to: {filePath}");// 实际保存文件的代码...}}}
}

如果希望允许用户指定不存在的路径而不过滤这种行为,只需将 CheckPathExists 设为 false 即可。

CSV 文件读写与 DataGridView 进阶

CSV(Comma Separated Values 逗号分隔值)文件是一种简单的文件格式,广泛用于存储表格数据。CSV 文件中的数据通常由行和列组成,每行数据代表表格中的一行,每列数据由逗号或其他分隔符分隔。

DataGridView主要属性:

DataSource

DataSource 属性用于设置 DataGridView 控件的数据源。常用的数据源类型有:

  • DataTable:从数据库查询得到的数据表/读取的文件。
  • List<T>:泛型集合,其中 T 是数据模型的类型。

行(Row 相关属性)

  • DataGridViewRow: 表示 DataGridView 控件中的一行。
  • DataGridViewRowCollection: 表示 DataGridView 控件中所有行的集合。
  • Rows: 通过此属性可以访问或操作行集合中的行。

列(Column 相关属性)

  • DataGridViewColumn: 表示 DataGridView 控件中的一列。
  • DataGridViewColumnCollection: 表示控件中所有列的集合。
  • Columns: 通过此属性可以访问或操作列集合中的列。

CSV(Comma Separated Values 逗号分隔值)

是一种文件格式(如.txt、.doc等),也可理解 .csv 文件就是一种特殊格式的纯文本文件。即是一组字符序列,字符之间已英文字符的逗号或制表符(Tab)分隔。

在 windows 系统环境上 .csv 文件打开方式有多种,如记事本、excel、Notepad++ 等,只要是文本编辑器都能正确打开。

CSV文件格式

CSV文件格式旨在存储表格数据,该数据通常包含行和列。每一行数据代表表格中的一行,每一列代表表格中的一列。CSV文件中每个数据字段之间都使用逗号分隔。每一行以换行符结束。如:

CSV 文件格式

姓名,年龄,性别
小明,20, 男
小红,18, 女
小华,19, 女

private void button1_Click(object sender, EventArgs e){if (openFileDialog1.ShowDialog()==DialogResult.OK){FileStream fs = new FileStream(openFileDialog1.FileName, FileMode.Open);StreamReader sr = new StreamReader(fs,Encoding.Default);DataTable dataTable = new DataTable();string data;//将读取到的一行数据存储到里面string[] lines; bool isFirst=true;//字符串==>DataTable==>DataSourcewhile ((data=sr.ReadLine())!=null){lines = data.Split(',');//将data里面的数据以,分割存储lines数组中if (isFirst){//判断是否是第一次读,如果是第一次读,就是读取每一列的第一个数据for (int i = 0; i < lines.Length; i++){dataTable.Columns.Add(lines[i]);}isFirst = false;}else{//如果不是第一次读取,就新增一行DataRow dataRow=  dataTable.NewRow();for (int i = 0; i < lines.Length; i++){dataRow[i] = lines[i];}dataTable.Rows.Add(dataRow);}}if (dataTable.Rows.Count==0){MessageBox.Show("没有数据");}else{dataGridView1.ColumnCount=dataTable.Columns.Count;for (int i = 0; i < dataTable.Columns.Count; i++){dataGridView1.Columns[i].HeaderText = dataTable.Columns[i].ColumnName;}for (int i = 0; i < dataTable.Rows.Count; i++){dataGridView1.Rows.Add(dataTable.Rows[i].ItemArray);}}sr.Close();fs.Close();}}private void button2_Click(object sender, EventArgs e){//DataSource==>DataTable==>字符串DataTable dataTable = new DataTable();for (int i = 0; i < dataGridView1.Columns.Count; i++){dataTable.Columns.Add(dataGridView1.Columns[i].HeaderText);}for (int i = 0; i < dataGridView1.Rows.Count; i++){DataRow dr=   dataTable.NewRow();for (int j = 0; j < dataGridView1.Columns.Count; j++){//将datagridView组件中某一个单元格的值传给dataTabledr[j] = dataGridView1[j, i].Value;}dataTable.Rows.Add(dr);}saveFileDialog1.Filter = "CSV files (*.csv)|*.csv";if (saveFileDialog1.ShowDialog()==DialogResult.OK){FileStream fs = new FileStream(saveFileDialog1.FileName, FileMode.Create);StreamWriter sw = new StreamWriter(fs,Encoding.Default);string data = null;for (int i = 0; i < dataTable.Columns.Count; i++){data += dataTable.Columns[i].ColumnName.ToString();if (i<dataTable.Columns.Count-1){data += ",";}}sw.WriteLine(data);data = null;for (int i = 0; i < dataTable.Rows.Count; i++){for (int j = 0; j < dataTable.Columns.Count; j++){data += dataTable.Rows[i][j].ToString();if (j < dataTable.Columns.Count - 1){data += ",";}}sw.WriteLine(data);data = null;}sw.Close();fs.Close();}}

CSV 文件读写简易版本

//读取CSV文件
StreamReader sr = new StreamReader(@"data.csv");
string line;
while ((line = sr.ReadLine()) != null)
{string[] values = line.Split(',');// 处理每一行的数据
}//写入CSV文件
StreamWriter sw = new StreamWriter(@"data.csv", true, Encoding.Default);
StringBuilder sb = new StringBuilder();
sb.Append("aa").Append(",").Append("bb").Append(",").Append("cc");
sw.WriteLine(sb);
sw.Close();

实践练习:实现登录注册功能

注册功能

注册功能需要创建一个新的文本文件,文件名以用户名命名,并在文件中存储用户的密码信息。

//注册功能
private void registerButton_Click(object sender, EventArgs e)
{string username = this.textBoxUsername.Text;string password = this.textBoxPassword.Text;string filePath = Path.Combine(UsersDirectory, username + ".txt");File.WriteAllText(filePath, password);
}

登录功能

登录功能需要验证用户输入的用户名和密码是否与存储的文件中的信息匹配。

//登录功能
private void loginButton_Click(object sender, EventArgs e)
{string username = this.textBoxUsername.Text;string password = this.textBoxPassword.Text;string filePath = Path.Combine(UsersDirectory, username + ".txt");if (File.Exists(filePath) && File.ReadAllText(filePath) == password){// 登录成功}else{// 登录失败}
}

在实现这些功能时,需要注意安全性问题,避免明文存储密码等敏感信息。可以通过加密等手段来增强安全性。

在这里插入图片描述

总结

以上是WinForms中文件操作和CSV处理的基础内容。掌握这些文件操作的使用方法对于WinForms开发者来说是非常重要的。

如果觉得文章还不错,可以点赞、收藏和转发,以支持作者继续创作更多教程。 另外本专栏将会持续更新,作者专栏中有已经更新完毕的C#基础教程!!!

这篇关于WinForms 零基础进阶教程:文件操作与 CSV 处理的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

无人叉车3d激光slam多房间建图定位异常处理方案-墙体画线地图切分方案

墙体画线地图切分方案 针对问题:墙体两侧特征混淆误匹配,导致建图和定位偏差,表现为过门跳变、外月台走歪等 ·解决思路:预期的根治方案IGICP需要较长时间完成上线,先使用切分地图的工程化方案,即墙体两侧切分为不同地图,在某一侧只使用该侧地图进行定位 方案思路 切分原理:切分地图基于关键帧位置,而非点云。 理论基础:光照是直线的,一帧点云必定只能照射到墙的一侧,无法同时照到两侧实践考虑:关

Java进阶13讲__第12讲_1/2

多线程、线程池 1.  线程概念 1.1  什么是线程 1.2  线程的好处 2.   创建线程的三种方式 注意事项 2.1  继承Thread类 2.1.1 认识  2.1.2  编码实现  package cn.hdc.oop10.Thread;import org.slf4j.Logger;import org.slf4j.LoggerFactory

Makefile简明使用教程

文章目录 规则makefile文件的基本语法:加在命令前的特殊符号:.PHONY伪目标: Makefilev1 直观写法v2 加上中间过程v3 伪目标v4 变量 make 选项-f-n-C Make 是一种流行的构建工具,常用于将源代码转换成可执行文件或者其他形式的输出文件(如库文件、文档等)。Make 可以自动化地执行编译、链接等一系列操作。 规则 makefile文件

零基础学习Redis(10) -- zset类型命令使用

zset是有序集合,内部除了存储元素外,还会存储一个score,存储在zset中的元素会按照score的大小升序排列,不同元素的score可以重复,score相同的元素会按照元素的字典序排列。 1. zset常用命令 1.1 zadd  zadd key [NX | XX] [GT | LT]   [CH] [INCR] score member [score member ...]

【生成模型系列(初级)】嵌入(Embedding)方程——自然语言处理的数学灵魂【通俗理解】

【通俗理解】嵌入(Embedding)方程——自然语言处理的数学灵魂 关键词提炼 #嵌入方程 #自然语言处理 #词向量 #机器学习 #神经网络 #向量空间模型 #Siri #Google翻译 #AlexNet 第一节:嵌入方程的类比与核心概念【尽可能通俗】 嵌入方程可以被看作是自然语言处理中的“翻译机”,它将文本中的单词或短语转换成计算机能够理解的数学形式,即向量。 正如翻译机将一种语言

[MySQL表的增删改查-进阶]

🌈个人主页:努力学编程’ ⛅个人推荐: c语言从初阶到进阶 JavaEE详解 数据结构 ⚡学好数据结构,刷题刻不容缓:点击一起刷题 🌙心灵鸡汤:总有人要赢,为什么不能是我呢 💻💻💻数据库约束 🔭🔭🔭约束类型 not null: 指示某列不能存储 NULL 值unique: 保证某列的每行必须有唯一的值default: 规定没有给列赋值时的默认值.primary key:

SWAP作物生长模型安装教程、数据制备、敏感性分析、气候变化影响、R模型敏感性分析与贝叶斯优化、Fortran源代码分析、气候数据降尺度与变化影响分析

查看原文>>>全流程SWAP农业模型数据制备、敏感性分析及气候变化影响实践技术应用 SWAP模型是由荷兰瓦赫宁根大学开发的先进农作物模型,它综合考虑了土壤-水分-大气以及植被间的相互作用;是一种描述作物生长过程的一种机理性作物生长模型。它不但运用Richard方程,使其能够精确的模拟土壤中水分的运动,而且耦合了WOFOST作物模型使作物的生长描述更为科学。 本文让更多的科研人员和农业工作者

【Linux 从基础到进阶】Ansible自动化运维工具使用

Ansible自动化运维工具使用 Ansible 是一款开源的自动化运维工具,采用无代理架构(agentless),基于 SSH 连接进行管理,具有简单易用、灵活强大、可扩展性高等特点。它广泛用于服务器管理、应用部署、配置管理等任务。本文将介绍 Ansible 的安装、基本使用方法及一些实际运维场景中的应用,旨在帮助运维人员快速上手并熟练运用 Ansible。 1. Ansible的核心概念

Flutter 进阶:绘制加载动画

绘制加载动画:由小圆组成的大圆 1. 定义 LoadingScreen 类2. 实现 _LoadingScreenState 类3. 定义 LoadingPainter 类4. 总结 实现加载动画 我们需要定义两个类:LoadingScreen 和 LoadingPainter。LoadingScreen 负责控制动画的状态,而 LoadingPainter 则负责绘制动画。