在VSTO C#中获取Excel范围内最后一个非空单元格,可以通过以下几种方法实现

1、使用End方法‌(类似Excel快捷键Ctrl+方向键):

Excel.Range lastCell = worksheet.Range["A1"].End(Excel.XlDirection.xlDown);

2、遍历单元格方法‌(适用于不连续数据):

Excel.Range lastCell = null; foreach (Excel.Range cell in worksheet.Range["A1:A100"]) { if (!string.IsNullOrEmpty(cell.Text.ToString())) { lastCell = cell; } }

‌3、使用SpecialCells方法‌(性能较好):

Excel.Range lastCell = worksheet.Range["A:A"].SpecialCells( Excel.XlCellType.xlCellTypeConstants, Excel.XlSpecialCellsValue.xlTextValues).Areas.Last();

4、Find方法‌(最可靠的方式):

Excel.Range lastCell = worksheet.Range["A:A"].Find( "*", Type.Missing, Excel.XlFindLookIn.xlValues, Excel.XlLookAt.xlPart, Excel.XlSearchOrder.xlByRows, Excel.XlSearchDirection.xlPrevious, false, Type.Missing, Type.Missing);

5、数组公式法‌(通过C#执行Excel公式):

string formula = "=LOOKUP(2,1/(A:A<>\"\"),A:A)"; Excel.Range lastCell = worksheet.Evaluate(formula) as Excel.Range;

注意事项:

  • 方法4(Find方法)是最可靠的解决方案68
  • 对于整列范围建议使用"A:A"格式5
  • 处理前应检查Worksheet是否为空5
  • 性能考虑:大数据量时Find方法最优
相关推荐
消失的旧时光-194315 分钟前
Kotlin 协程最佳实践:用 CoroutineScope + SupervisorJob 替代 Timer,实现优雅周期任务调度
android·开发语言·kotlin
错把套路当深情22 分钟前
Kotlin保留小数位的三种方法
开发语言·python·kotlin
Jackiejin52628 分钟前
WPS表格选择性粘贴快捷键怎么使用?WPS如何给表格某一行都加上指定数字?
数据分析·excel·wps
wangnaisheng1 小时前
【C#】EventHandler的使用
c#
赵谨言2 小时前
基于Python Web的大数据系统监控平台的设计与实现
大数据·开发语言·经验分享·python
唐青枫2 小时前
C#.NET Cronos 实战:优雅解析与执行 Cron 表达式
c#·.net
专注前端30年2 小时前
Vue2 中 v-if 与 v-show 深度对比及实战指南
开发语言·前端·vue
办公解码器2 小时前
Excel怎么将八位数字设置为日期格式?
excel
gis92 小时前
批量地址解析坐标,支持WPS、EXCEL软件,支持导出SHP、GEOJSON、DXF等文件格式
excel·wps
星竹晨L3 小时前
C++继承机制:面向对象编程的基石
开发语言·c++