Как получить конкретный диапазон в Excel через COM Interop? - PullRequest
7 голосов
/ 01 декабря 2010

у меня следующая проблема.Я должен прочитать файл Excel через COM-взаимодействия.Я новичок в программировании с COM-взаимодействием.

Я ищу конкретную строку, используя это:

this.sheet = (Excel.Worksheet)this.excelApp.Workbook.Sheets.Item[this.sheetname];
            this.sheet.Activate();
            Excel.Range firstRow = this.sheet.Range["A1", "XFD1"];
            Excel.Range foundRange = firstRow.Find(
                this.StringISearch,
                Type.Missing,
                Type.Missing,
                Excel.XlLookAt.xlWhole,
                Excel.XlSearchOrder.xlByColumns,
                Excel.XlSearchDirection.xlNext,
                false,
                false,
                Type.Missing);

Нет, я хочу использовать foundRange в качестве отправной точки для получения другого диапазона.1006 *

Примерно так

Excel.Range MyRange = this.sheet.Range[foundRange + 2 rows, + 1 column & lastRow];

Я не вижу способа сделать это.Есть ли один?

1 Ответ

28 голосов
/ 01 декабря 2010

Хорошо, после некоторого сна я нашел ответ.

 int startColumn = Header.Cells.Column;
 int startRow = header.Cells.Row + 1;
 Excel.Range startCell = this.sheet.Cells[startRow, startColumn];
 int endColumn = startColumn + 1;
 int endRow = 65536;
 Excel.Range endCell = this.sheet.Cells[endRow, endColumn];
 Excel.Range myRange = this.sheet.Range[startCell, endCell];
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...