在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方法最优
相关推荐
你怎么知道我是队长5 小时前
C语言---枚举变量
c语言·开发语言
李慕婉学姐5 小时前
【开题答辩过程】以《基于JAVA的校园即时配送系统的设计与实现》为例,不知道这个选题怎么做的,不知道这个选题怎么开题答辩的可以进来看看
java·开发语言·数据库
吃茄子的猫5 小时前
quecpython中&的具体含义和使用场景
开发语言·python
云栖梦泽5 小时前
易语言中小微企业Windows桌面端IoT监控与控制
开发语言
数据大魔方6 小时前
【期货量化实战】日内动量策略:顺势而为的短线交易法(Python源码)
开发语言·数据库·python·mysql·算法·github·程序员创富
李建军7 小时前
界止签章宗地号替换工具
c#
qq_425263327 小时前
.net开发框架和语言
c#
Edward.W7 小时前
Python uv:新一代Python包管理工具,彻底改变开发体验
开发语言·python·uv
小熊officer7 小时前
Python字符串
开发语言·数据库·python
武藤一雄7 小时前
C# 关于多线程如何实现需要注意的问题(持续更新)
windows·后端·microsoft·c#·.net·.netcore·死锁