Метод Excel.Range.Find - PullRequest
       11

Метод Excel.Range.Find

4 голосов
/ 12 апреля 2010

Я использую объект взаимодействия 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 как ноль, всегда мой 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

, где при нажатии на ячейку Sep-08 я получаю 9/1/2008 в поле формулыВ Excel я также пытался найти 01.09.2008, но он варьируется в зависимости от системы в соответствии с форматом даты RegionalSettings ...

Пожалуйста, помогите мне.в основном я делаю, чтобы получить адрес ячейки строки поиска

1 Ответ

4 голосов
/ 15 апреля 2010

Используя 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);

Пример Microsoft можно найти по адресу Как автоматизировать Excel с помощью Visual C # для заполнения или получения данных в диапазоне с использованием массивов .

...