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

 更新时间:2024年12月09日 10:41:40   作者:凌盛羽  
在C#编程中,CSV(Comma Separated Values)文件是一种常见的数据存储格式,用于存储表格数据,如数据库导出或报表,CSV文件以其简单、易于处理和跨平台兼容性而受到广泛使用,本篇文章将深入探讨如何在C#中进行CSV文件的读写操作,需要的朋友可以参考下

一、变量定义

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

二、加载主窗口

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

三、创建表头

#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

四、向表中添加数据

#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

五、从表中读取数据

#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

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

#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

七、测试验证

在这里插入代码片

到此这篇关于C#对Excel表csv文件的读写操作详解的文章就介绍到这了,更多相关C# csv文件的读写内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • DevExpress之ChartControl实现饼状图百分比演示实例

    DevExpress之ChartControl实现饼状图百分比演示实例

    这篇文章主要介绍了DevExpress之ChartControl实现饼状图百分比演示的方法,实例讲述了窗体与图形绘制函数的用法,需要的朋友可以参考下
    2014-10-10
  • C# XML操作类分享

    C# XML操作类分享

    这篇文章主要分享了C# XML操作类的实例代码,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-06-06
  • c#程序定期把内存信息记录到log日志示例

    c#程序定期把内存信息记录到log日志示例

    这篇文章主要介绍了c#程序定期把内存信息记录到log日志示例,需要的朋友可以参考下
    2014-04-04
  • C#实现文件分割和合并的示例详解

    C#实现文件分割和合并的示例详解

    这篇文章主要为大家详细介绍了如何利用C#实现文件分割和合并的功能,文中的示例代码讲解详细,对我们学习C#有一定的帮助,感兴趣的小伙伴可以跟随小编一起了解一下
    2022-12-12
  • C#Js时间格式化问题简单实例

    C#Js时间格式化问题简单实例

    这篇文章介绍了C#Js时间格式化问题简单实例,有需要的朋友可以参考一下
    2013-10-10
  • 使用C#校验画布签名图片是否为空白

    使用C#校验画布签名图片是否为空白

    这篇文章主要为大家详细介绍了如何使用C#校验画布签名图片是否为空白,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下
    2024-11-11
  • C#串口通讯概念及简单的实现方法

    C#串口通讯概念及简单的实现方法

    这篇文章主要给大家介绍了关于C#串口通讯概念及简单的实现方法,文中通过示例代码介绍的非常详细,对大家的学习或者使用C#具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-03-03
  • 在C#中如何使用ResNet50v2进行图像识别

    在C#中如何使用ResNet50v2进行图像识别

    ONNX 运行时推理可以实现更快的客户体验和更低的成本,支持来自深度学习框架如 PyTorch和TensorFlow/Keras以及经典机器学习库如 scikit-learn、LightGBM、XGBoost 等的模型,这篇文章主要介绍了在C#中如何使用ResNet50v2进行图像识别,需要的朋友可以参考下
    2024-07-07
  • 如何使用C#操作幻灯片

    如何使用C#操作幻灯片

    一般大家经常会用PPT遥控翻页笔来遥控幻灯片,本文确为大家介绍了使用C#制作一个遥控幻灯片,感兴趣的朋友可以参考下
    2015-07-07
  • WPF实现3D翻牌式倒计时特效

    WPF实现3D翻牌式倒计时特效

    这篇文章主要为大家详细介绍了WPF实现3D翻牌式倒计时特效,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-09-09

最新评论