2010-11-30 1 views
7

私は以下の問題があります。私はCOM interopを通してExcelファイルを読まなければなりません。私はCOM interopでプログラミングするのが初めてです。COM Interopを使用してExcelで特定の範囲を取得する方法?

私はこれを使用して、特定の文字列を検索:

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を使用したいです。この

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

よう

何かが私はこれを行う方法が表示されません。 1つはありますか?

答えて

25

さて、眠った後、私は答えを見つけました。

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]; 
関連する問題