I have to read an excel file through a COM interop. I search for a specific string using this:
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);
Now I want to use the foundRange as a starting point to get another range.
Something like this
Excel.Range MyRange = this.sheet.Range[foundRange + 2 rows, + 1 column & lastRow];
I don't see a way to do this. Is there one?
Excel. Range that contains a single cell, an entire column, an entire row, or it can be a string that names a single cell in the language of the application.
Okay, after some sleep i have found the answer.
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];
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With