C# 在excel中查找及替换数据
? 在使用Excel处理数据时,有时候工作表内容很多,如果手动地一行一行的找数据很难发现它们在哪个地方。微软Excel给我们提供了一个很强大的数据处理功能-查找和替换,通过这个功能,我们可以快速地找到想要的数据并一次性对一个或多个单元格的数据进行更改或更新。但对于开发来说,有时我们可能需要通过编程的方式来实现它。这篇文章讲述的是怎样使用C#来实现excel的查找和替换功能。 这是Excel工作表的截图: 我需要上表格中单元格A5和A6的数据Canada替换为British。 详细步骤: 首先,新建一个visual C#控制台项目,添加引用并使用如下命名空间: using System.Drawing;
using Spire.Xls;
? 步骤1:新建一个Workbook类的对象,并加载excel文档。 Workbook workbook = new Workbook();
workbook.LoadFromFile("统计表.xlsx");
?? 步骤2:获取需要替换文本的工作表,此处是第一个工作表。 Worksheet sheet = workbook.Worksheets[0];
? 步骤3:通过调用Worksheet.FindAllString()方法,查找文本Canada并将它们全部替换为British。这里我还设置了高亮色,方便快速地找到替换过的数据。 CellRange[] ranges = sheet.FindAllString("Canada",false,false);
foreach (CellRange range in ranges)
{
range.Text = "British";
range.Style.Color = Color.LawnGreen;
}
? 步骤4:保存文件并重新打开。 workbook.SaveToFile("替换.xlsx");
System.Diagnostics.Process.Start("替换.xlsx");
? 效果图: ? 全部代码: using System.Drawing;
using Spire.Xls;
namespace Excel查找和替换
{
class Program
{
static void Main(string[] args)
{
Workbook workbook = new Workbook();
workbook.LoadFromFile("统计表.xlsx");
Worksheet sheet = workbook.Worksheets[0];
CellRange[] ranges = sheet.FindAllString("Canada",false);
foreach (CellRange range in ranges)
{
range.Text = "British";
range.Style.Color = Color.LawnGreen;
}
workbook.SaveToFile("替换.xlsx");
System.Diagnostics.Process.Start("替换.xlsx");
}
}
}
? 在这个项目中,我使用的是免费版Spire.XLS,需要注意的是这个例子中我查找和替换的是string类型的数据,也就是文本,因此使用的是Worksheet.FindAllString()方法。如果要查找和替换数字,改为FindAllNumber()就可以了。 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
- PyQt4 – “RuntimeError:底层C/C++对象已被删除”
- c – std :: vector vs std :: stack
- C#3.0使用EventLog类写Windows事件日志的方法
- Ajax 跨域请求 jsonp获取json数据
- Ruby模板中的翡翠式块(Haml?)
- oracle – 有没有办法在出错时回滚并退出psql脚本?
- c – 如何使用Boost库计算两个时间戳之间的微秒时差
- objective-c – “dwarfdump二进制文件必须存在且必须可执行
- ruby-on-rails-4 – database_cleaner正在擦除我的开发数据
- flex获取对象类型 并通过类名实例化对象