C# WinForm 使用Microsoft.Office.Interop.Excel对Excel文件表格的单元格值进行修改操作

该文章介绍了如何在C#的WinForm应用中使用Microsoft.Office.Interop.Excel库来修改Excel文件的工作表单元格值。首先,需通过NuGet添加引用,然后创建一个内部类封装修改方法,接受文件路径、工作表索引和键值对作为参数,遍历键值对并更新对应单元格的值。最后展示了如何调用这个方法。

C# WinForm 使用Microsoft.Office.Interop.Excel对Excel文件表格的单元格值进行修改操作

准备工作

1、添加引用

在引用位置点击右键
在这里插入图片描述点击管理NUGet程序包
在这里插入图片描述搜索Excel,在搜索结果中点击Microsoft.Office.Interop.Excel
在这里插入图片描述然后点击安装即可,搜不到的话,在右侧程序包源位置改成全部再次搜索

在这里插入图片描述

添加类文件

对准项目,点击右键,在弹出菜单选择添加,选择类
在这里插入图片描述类名称随意,然后清空新建类得到全部内容,把下面封装号的源代码全部粘贴进去,项目名称改成你自己原本的项目名称。

源代码

1、封装好的类

在这里插入图片描述

using System;
using System.Collections.Generic;
using Excel = Microsoft.Office.Interop.Excel;

namespace 改成你自己的项目名称
{

	internal class ExcelChange
	{
		/// <summary>
		/// Excel写入数据,修改工作表单元格数值
		/// </summary>
		/// <param name="FileName">文件完整路径</param>
		/// <param name="WorksheetIndex">工作表索引值</param>
		/// <param name="kv">单元格位置和数值</param>
		public void Excel写入数据(string FileName, int WorksheetIndex, SortedList<string, string> kv)
		{
			//创建excel应用程序
			Excel.Application myApp = new Excel.Application();
			//打开文件
			Excel.Workbook wb = myApp.Workbooks.Open(FileName);
			//选择工作表
			Excel.Worksheet ws = wb.Worksheets[WorksheetIndex];//sheet的索引从1开始

			//获取工作表的名称
			string wsName = ws.Name;
			Console.WriteLine(wsName);
			//数据表的有效数据行数
			int wsUsedRows = ws.UsedRange.Rows.Count;
			Console.WriteLine(wsUsedRows);
			//数据表的有效数据列数
			int wsUsedColumns = ws.UsedRange.Columns.Count;
			Console.WriteLine(wsUsedColumns);
			foreach (string key in kv.Keys)
			{
				//修改数值
				ws.Rows[ws.Range[key].Row].Cells[ws.Range[key].Column].Value = kv[key];
			}
			//保存文件、关闭文件
			wb.Save();
			wb.Close();
			//退出excel应用程序
			myApp.Quit();
		}
	}
}

2、调用方法

using System;
using System.Collections.Generic;
using 项目名称.Properties;

ExcelChange Ec = new ExcelChange();

private void button3_Click(object sender, EventArgs e)
{
	SortedList<string, string> sl = new SortedList<string, string>
	{
		{ "A1", "qq" },
		{ "A2", "qd" },
		{ "C2", "qd" }
	};
	Ec.Excel写入数据(@"D:\Users\toss\Desktop\123.xlsx", 1, sl);
}

未完待续

没有用到新建,改变格式等操作,暂时不写代码了

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

toss007

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值