当前位置: 首页 > news >正文

vsto快速在excel中查找某个字符串

是的,使用foreach循环遍历 Excel.Range 可能会较慢,特别是在大型数据集上。为了提高效率,你可以考虑使用 Value 属性一次性获取整个范围的值,然后在内存中搜索文本。这样可以减少与 Excel 之间的交互次数,提高性能。

以下是修改后的代码:

csharp
using System;
using System.Linq;
using Excel = Microsoft.Office.Interop.Excel;namespace ExcelSearchExample
{class Program{static void Main(string[] args){// 连接到正在运行的 Excel 实例或启动新的 Excel 实例Excel.Application excelApp = new Excel.Application();excelApp.Visible = true; // 设置 Excel 可见// 获取活动工作簿和工作表Excel.Workbook workbook = excelApp.ActiveWorkbook;Excel.Worksheet worksheet = workbook.ActiveSheet;// 调用自定义的查找方法Excel.Range foundRange = FindTextInWorksheet(worksheet, "关键字");// 处理找到的结果if (foundRange != null){Console.WriteLine("找到在单元格:" + foundRange.Address);}else{Console.WriteLine("未找到基。");}// 释放资源System.Runtime.InteropServices.Marshal.ReleaseComObject(worksheet);System.Runtime.InteropServices.Marshal.ReleaseComObject(workbook);System.Runtime.InteropServices.Marshal.ReleaseComObject(excelApp);}static Excel.Range FindTextInWorksheet(Excel.Worksheet worksheet, string searchText){// 获取整个工作表的值Excel.Range searchRange = worksheet.UsedRange;object[,] values = searchRange.Value;// 获取数组的维度int rowCount = values.GetLength(0);int colCount = values.GetLength(1);// 遍历数组查找文本for (int row = 1; row <= rowCount; row++){for (int col = 1; col <= colCount; col++){if (values[row, col] != null && values[row, col].ToString().Contains(searchText)){// 计算找到的单元格在 Excel 中的位置int excelRow = searchRange.Row + row - 1;int excelCol = searchRange.Column + col - 1;// 返回找到的单元格return worksheet.Cells[excelRow, excelCol] as Excel.Range;}}}return null;}}
}


这个修改后的代码首先将整个 UsedRange 的值读入到一个二维数组中,然后在内存中遍历数组以查找匹配的文本。这样可以减少与 Excel 之间的交互次数,从而提高性能。

http://www.lryc.cn/news/319254.html

相关文章:

  • Unity类银河恶魔城学习记录10-1 10-2 P89,90 Character stats - Stat script源代码
  • 西门子TIA中配置Anybus PROFINET IO Slave 模块
  • 在 Rust 中使用 Serde 处理json
  • 【数据库】数据库介绍
  • python 第三方库(PyPinyin\shortuuid\json)
  • 一文解读ISO26262安全标准:术语(二)
  • 【Datawhale学习笔记】从大模型到AgentScope
  • QWebEngineView添加自定义网址协议UrlScheme
  • react中使用腾讯地图
  • deepin23beta中SQLite3数据库安装与使用
  • 前后端分离项目环境搭建
  • HTML静态网页成品作业(HTML+CSS)——家乡漳州介绍设计制作(1个页面)
  • 世界第二对海信到底有多重要?
  • 多站合一的音乐搜索下载助手PHP源码l亲测
  • webserver烂大街?还有必要做么?
  • 3.Redis命令
  • xray问题排查,curl: (35) Encountered end of file(已解决)
  • 【数据库】Oracle内存结构与参数调优
  • PS学习-抠图-蒙版-冰块酒杯等透明物体
  • 绝赞春招拯救计划 -- 操作系统,组成原理,计网
  • c语言:于龙加
  • AcWing 790:数的三次方根 ← 浮点数二分
  • 【LLM】LLama2模型(RMSNorm、SwiGLU、RoPE位置编码)
  • 【力扣白嫖日记】1934.确认率
  • TinTin Web3 动态精选:以太坊坎昆升级利好 Layer2,比特币减半进入倒计时
  • PCL 高斯投影反算:高斯投影坐标转大地坐标(C++详细过程版)
  • 解决:IDEA编译Java程序时报编译失败
  • vue+vite根据版本号清空用户浏览器缓存
  • AXI CANFD MicroBlaze 测试笔记
  • 操作系统——cpu、内存、缓存介绍