首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >Excel.Range.Find方法

Excel.Range.Find方法
EN

Stack Overflow用户
提问于 2010-04-12 19:24:49
回答 1查看 34.4K关注 0票数 5

我正在使用Excel互操作对象,并尝试通过以下方法查找指定范围内的日期

代码语言:javascript
运行
复制
Excel.Range rngFind = WS.get_Range(strFromRange, strToRange).Find(strFind, Type.Missing,
                Excel.XlFindLookIn.xlFormulas, Excel.XlLookAt.xlPart, Excel.XlSearchOrder.xlByRows,
                Excel.XlSearchDirection.xlNext, false, false, false);

但是我得到的rngFind总是为空,我的strFind = "Sep-08“我用Excel.XlFindLookIn.xlFormulas和Excel.XlFindLookIn.xlValues都尝试过

我的excel文件如下所示

代码语言:javascript
运行
复制
Sep-08  Oct-08  Nov-08  Dec-08  Jan-09  Feb-09  Mar-09  Apr-09  May-09  Jun-09  Jul-09

当我点击Sep-08单元格时,我在Excel的公式字段中得到了9/1/2008,我也尝试过搜索9/1/2008,但根据RegionalSettings日期格式,它因系统而异……

请帮帮我。基本上,我这样做是为了获取查找字符串的单元地址

EN

回答 1

Stack Overflow用户

发布于 2010-04-15 11:36:11

使用Office 2007,可以直接从Visual Studio生成Interop。我使用以下代码查找有问题的单元:

代码语言:javascript
运行
复制
using System.Reflection;
using Microsoft.Office.Interop.Excel;

object False = false;
object True = true;

_Application excel = new Microsoft.Office.Interop.Excel.ApplicationClass();

Workbook wb = excel.Workbooks._Open(@"C:\tmp\StackOverflow.xlsx",False, False,Missing.Value,Missing.Value,False,False,Missing.Value,Missing.Value,False,Missing.Value,Missing.Value,True);

_Worksheet ws = (_Worksheet)wb.Worksheets[1];

string from = "A1";
string to = "B1";

Range rng = ws.get_Range(from,to);

Range findRng = rng.Find("Sep-08",Missing.Value,XlFindLookIn.xlValues,Missing.Value,Missing.Value,XlSearchDirection.xlNext,False,False,Missing.Value);

你可以在How to automate Excel by using Visual C# to fill or to obtain data in a range by using arrays上找到微软的例子。

票数 5
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/2621620

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档