Excel.Range.Find方法

时间:2010-04-12 11:24:49

标签: c# interop ms-office

我正在使用Excel互操作对象并尝试通过以下方法

查找指定范围内的日期
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为null总是我的strFind =“Sep-08”我尝试使用Excel.XlFindLookIn.xlFormulas和Excel.XlFindLookIn.xlValues

我的excel文件看起来像这样

Sep-08  Oct-08  Nov-08  Dec-08  Jan-09  Feb-09  Mar-09  Apr-09  May-09  Jun-09  Jul-09

当wheni点击08年9月的单元格时,我在Excel的公式字段中得到9/1/2008 我也试过搜索9/1/2008,但它根据RegionalSettings Date格式按系统变化......

请帮帮我。基本上我正在做的是获取发现字符串的单元格地址

1 个答案:

答案 0 :(得分:4)

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

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找到Microsoft示例。