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

七、测试验证

在这里插入代码片

相关推荐
晓晓hh2 小时前
JavaSE学习——迭代器
java·开发语言·学习
Laurence2 小时前
C++ 引入第三方库(一):直接引入源文件
开发语言·c++·第三方库·添加·添加库·添加包·源文件
kyriewen112 小时前
你点的“刷新”是假刷新?前端路由的瞒天过海术
开发语言·前端·javascript·ecmascript·html5
014-code2 小时前
String.intern() 到底干了什么
java·开发语言·面试
421!3 小时前
GPIO工作原理以及核心
开发语言·单片机·嵌入式硬件·学习
codeJinger3 小时前
【Python】操作Excel文件
python·excel
摇滚侠3 小时前
JAVA 项目教程《苍穹外卖-12》,微信小程序项目,前后端分离,从开发到部署
java·开发语言·vue.js·node.js
Darkdreams3 小时前
关于解决Cannot resolve com.microsoft.sqlserversqljdbc44.0报错问题
microsoft
@insist1233 小时前
网络工程师-生成树协议(STP/RSTP/MSTP)核心原理与应用
服务器·开发语言·网络工程师·软考·软件水平考试
野生技术架构师4 小时前
2026年牛客网最新Java面试题总结
java·开发语言