C#对Excel表csv文件的读写操作

C#对Excel表csv文件的读写

一、变量定义

csharp 复制代码
#region 变量定义
private string CurAppExeDir = System.AppDomain.CurrentDomain.BaseDirectory;
private string TestFileName = "xDemoTest.csv";
#endregion

二、加载主窗口

csharp 复制代码
#region 加载主窗口
private void xDemoMainForm_Load(object sender, EventArgs e)
{
	Create_Table_Header();
	Read_Data_Table(CurAppExeDir + TestFileName);
}
#endregion

三、创建表头

csharp 复制代码
#region 创建表头
private void Create_Table_Header()
{
	/* 文件路径 + 名称 */
	string dir = CurAppExeDir + TestFileName;

	/* 文件已存在 */
	if (File.Exists(dir) == true) return;

	/* 创建文件流 */
	using(FileStream fileStream = new FileStream(dir, FileMode.Create, FileAccess.Write))
	{
		/* 创建写文件流 */
		StreamWriter streamWriter = new StreamWriter(fileStream);

		/* 写入表头 */
		const string header = "序号,姓名,学号,性别,专业";
		streamWriter.WriteLine(header);

		/* 关闭写文件流 */
		streamWriter.Close();
	}
}
#endregion

四、向表中添加数据

csharp 复制代码
#region 向表中添加数据
private void Append_Data_Table(string dir, string text)
{
	/* 文件不存在 */
	if (File.Exists(dir) == false) return;

	/* 创建文件流 */
	using (FileStream fileStream = new FileStream(dir, FileMode.Append, FileAccess.Write))
	{
		/* 创建写文件流 */
		StreamWriter streamWriter = new StreamWriter(fileStream);

		/* 写入表头 */
		streamWriter.WriteLine(text);

		/* 关闭写文件流 */
		streamWriter.Close();
	}
}
#endregion

五、从表中读取数据

csharp 复制代码
#region 从表中读取数据
private List<string> Read_Data_Table(string dir)
{
	List<string> readData = new List<string>();

	/* 文件不存在 */
	if (File.Exists(dir) == false) return readData;

	/* 创建文件流 */
	using (FileStream fileStream = new FileStream(dir, FileMode.Open, FileAccess.Read))
	{
		/* 创建读文件流 */
		StreamReader streamReader = new StreamReader(fileStream);

		/* 是否到达文件末尾 */
		while (streamReader.EndOfStream == false)
		{
			/* 读数据 */
			string text = streamReader.ReadLine();
			Console.WriteLine(text);
			readData.Add(text);
		}

		/*  关闭读文件流 */
		streamReader.Close(); 
	}
	return readData;
}
#endregion

六、单击按钮向表中添加数据

csharp 复制代码
#region 单击按钮
static UInt16 count = 1;
private void ButtonTest1_Click(object sender, EventArgs e)
{
	
	//序号,姓名,学号,性别,专业;
	string dir = CurAppExeDir + TestFileName;
	string ts = (DateTime.Now.ToUniversalTime() - new DateTime(1970, 1, 1)).TotalMilliseconds.ToString().Substring(5,8);
	string text = count.ToString() + ",凌晨," + ts + ",女," + "核弹维修保养" + count.ToString();
	Append_Data_Table(dir, text);
	count += 1;
}
#endregion

七、测试验证

在这里插入代码片

相关推荐
2501_947575803 小时前
计算机毕业设计之jsp开山车行二手车交易系统
java·开发语言·hadoop·python·信息可视化·django·课程设计
国科安芯3 小时前
ASC4T245S分组双向控制架构深度解析:独立DIR/OE控制、QFN16封装与混合方向总线桥接
单片机·嵌入式硬件·物联网·fpga开发·架构·risc-v
骑士雄师3 小时前
java面试题 4:鉴权
java·开发语言
KaMeidebaby4 小时前
卡梅德生物技术快报|蛋白 N 端测序在重组贻贝融合蛋白表征中的应用,解决原核表达序列偏移工艺难题
前端·人工智能·物联网·算法·百度
时间的拾荒人4 小时前
C语言字符函数与字符串函数完全指南
c语言·开发语言
2501_948106915 小时前
计算机毕业设计之基于jsp教科研信息共享系统
java·开发语言·信息可视化·spark·课程设计
取经蜗牛5 小时前
Python 第一阶段完全指南:从零到第一个实用工具
开发语言·python
JNX_SEMI5 小时前
AT2401C 2.4GHz 全集成射频前端单芯片技术解析
前端·单片机·嵌入式硬件·物联网·硬件工程
dog2506 小时前
从重尾到截断流量模型的演进
开发语言·php
qq_401700416 小时前
Qt QSS 完全入门写出漂亮界面以及解决样式不生效问题
开发语言·qt