C#中的EXCEL的查找操作

最重要的是,range.find之后还要用range.findnext,就可以遍历所有的查找到的数据
代码如下:
using Microsoft.Office.Interop.Excel;
Application myExcel = new Application(); //开启EXCEL 服务
             object missing = System.Reflection.Missing.Value;
             myExcel.Application.Workbooks.Open(strExcelPath, missing, missing, missing, missing, missing, missing,
                 missing, missing, missing, missing, missing, missing, missing, missing);
             Workbook myBook = myExcel.Workbooks[1]; //获取工作簿
             _Worksheet sheet = (Worksheet)myBook.Sheets[ "RP750PDF" ]; //获取sheet
             int iCnt = sheet.UsedRange.Count;
             Excel.Range rgUsed, rgFound;
             rgUsed = sheet.get_Range( "A2:A10" ); //获取a2-10范围的梅子
             rgFound = (Excel.Range)rgUsed.Find( "RP757c-" , Type.Missing, //“RP757C-”即是要查找的字符串
                 Excel.XlFindLookIn.xlValues, //查找值,或者xlFormulas查找公式等
                 Excel.XlLookAt.xlPart, //这里用xlWhole返回的一直是空指针
                 Excel.XlSearchOrder.xlByRows, //按行查找
                 Excel.XlSearchDirection.xlNext, //建议就用xlNext
false , false );
             Range rgTmp = rgFound;

            do
            {
                var item = rgTmp.get_Value();
                int iRowNum = rgTmp.Row;
                int iColNum = rgTmp.Column;
                rgTmp = rgUsed.FindNext(rgTmp);
            } while (rgTmp.Address != rgFound.Address);//记录第一个找到的range地址,当下一个单元格的地址与第一个相同,则跳出。

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值