ExcelTip.Net留存知识帖 ---【注:附件之前被网盘供应商清空后,现已修复-现已修复-现已修复为本地下载!】
现在位置:首页 > E问E答 > 函数与公式 > 如何返回连续输入的某列中最后一个非空单元格的内容?

如何返回连续输入的某列中最后一个非空单元格的内容?

作者:绿色风 分类: 时间:2022-08-17 浏览:95
楼主
biaotiger1
Q:如何返回连续输入的某列中最后一个非空单元格的内容?
A:如下图,数据区域从A2开始且行数不定。

 
则在A1中可输入如下公式返回连续输入的当前列中最后一个非空单元格的内容:
  1. =INDIRECT("a"&COUNTA(A2:A1048576)+1)

运用此公式应注意如下:
1、从A2单元格向下到最后一个非空单元格构成的区域(上图中为A2:A20的区域)中不可有空单元格。
2、从A2开始的该列第一个非空单元格(上图中为A20)以下不可有非空单元格。
返回连续输入的某列中最后一个非空单元格的内容.rar
2楼
棉花糖
对于如果有空格的情况的话也可以的。
方法1.=INDIRECT("a"&MAX(MATCH(CHAR(1),A:A,-1),MATCH(9E+307,A:A,1))),速度快
方法2:=INDIRECT("A"&MAX((A:A<>"")*ROW(A:A))) 数组公式,字符少,但是以速度为代价,竞赛题时用,平时不建议。
方法3:vba
Sub lastcell()
[b1] = Range("A1048576").End(xlUp)
End Sub
还有其他我不知的方法
3楼
apolloh
如果没有biaotiger1兄所说的前提,请参考:
如何判断某列中最后一个文本或数值所在的行? http://www.exceltip.net/thread-1334-1-1.html
4楼
gouweicao78
不建议使用INDIRECT,可以改用非易失性函数:
  1. =INDEX(A:A,COUNTA(A2:A1048576)+1)
或者用数据库函数统计,其中C1:C2可以是其他两个空单元格,这个方法是避免输入A2:A1048576的:
  1. =INDEX(A:A,DCOUNTA(A:A,1,C1:C2)+1)

免责声明

有感于原ExcelTip.Net留存知识的价值及部分知识具有的时间限定性因素, 经与ExcelTip.Net站长Apolloh商议并征得其同意, 现将原属ExcelTip.Net的知识帖采集资料于本站点进行展示, 供有需要的人士查询使用,也慰缅曾经的论坛时代。 所示各个帖子的原作者如对版权有异议, 可与本人沟通提出,或于本站点留言,我们会尽快处理。 在此,感谢ExcelTip.Net站长Apolloh的支持,感谢本站点所有人**绿色风(QQ:79664738)**的支持与奉献,特此鸣谢!
------本人网名**KevinChengCW(QQ:1210618015)**原ExcelTip.Net总版主之一

评论列表
sitemap