How to get specific Range in Excel through COM Interop?(如何通过 COM 互操作获取 Excel 中的特定范围?)
问题描述
我必须通过 COM 互操作读取 excel 文件.我使用这个搜索一个特定的字符串:
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);
现在我想以foundRange为起点来获取另一个范围.
Now I want to use the foundRange as a starting point to get another range.
类似的东西
Excel.Range MyRange = this.sheet.Range[foundRange + 2 rows, + 1 column & lastRow];
我没有办法做到这一点.有吗?
I don't see a way to do this. Is there one?
推荐答案
好的,睡了一会儿我找到了答案.
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];
这篇关于如何通过 COM 互操作获取 Excel 中的特定范围?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:如何通过 COM 互操作获取 Excel 中的特定范围?


基础教程推荐
- 全局 ASAX - 获取服务器名称 2022-01-01
- JSON.NET 中基于属性的类型解析 2022-01-01
- 经典 Asp 中的 ResolveUrl/Url.Content 等效项 2022-01-01
- 在 VS2010 中的 Post Build 事件中将 bin 文件复制到物 2022-01-01
- 如何动态获取文本框中datagridview列的总和 2022-01-01
- 从 VS 2017 .NET Core 项目的发布目录中排除文件 2022-01-01
- 首先创建代码,多对多,关联表中的附加字段 2022-01-01
- 是否可以在 asp classic 和 asp.net 之间共享会话状态 2022-01-01
- 错误“此流不支持搜索操作"在 C# 中 2022-01-01
- 将事件 TextChanged 分配给表单中的所有文本框 2022-01-01