【VBA研究】用VBA取得EXCEL有效行列数方法比较

您所在的位置:网站首页 如何统计excel列数 【VBA研究】用VBA取得EXCEL有效行列数方法比较

【VBA研究】用VBA取得EXCEL有效行列数方法比较

2024-07-15 07:41| 来源: 网络整理| 查看: 265

作者:iamlaosong

我常用下面方式取得有效行数:

maxrow=sheets(1).[A65536].End(xlUp).Row

这一句的含义是从A列65536行开始向上找,碰到第一个非空单元格的行号就是有效行数。

实际使用中发现这种方法存在2个问题:

1、高低版本不兼容,2007版最大行数增加以后,就不能用65536了,而要用1048576,可以先判断再决定用哪个数字,即用下列语句代替原来的一句,假定文件名变量为rptfile:

        If Right(rptfile, 3) = "xls" Then             maxrow = [A65536].End(xlUp).Row         Else             maxrow = [A1048576].End(xlUp).Row

 

        End If

对于文件自身,用系统变量ThisWorkbook.name(全路径名称是ThisWorkbook.FullName):

            If Right(ThisWorkbook.name, 3) = "xls" Then                 maxrow = Sheets(name).[A65536].End(xlUp).Row             Else                 maxrow = Sheets(name).[A1048576].End(xlUp).Row             End If

2、当最后一行不为空时,用这个方法取不到正确的值。

3、其实也可以从上往下找,下面语句的意思是从A列第1行往下找,碰到最后一个非空单元格的行号就是有效行数。

            maxrow = [A1].End(xlDown).Row

这种方法要求有效行数内,A列单元格都是非空,否则就不准了。  

 

下面说明用VBA得到EXCEL表格中的行数和列数的特点,以便根据需要选用

 

每种方法中上面的是Excel的行数,下面的是Excel的列数。方法1:   ActiveSheet.UsedRange.Rows.Count      ActiveSheet.UsedRange.Columns.Count        缺点:有时可能会比实际数大一些,原因是如果你把最后几行(列)数据清除后(非整行或整列删除),用这个命令仍返回未清除前的值。就是说现在虽然是空的,但是你曾经用过也算你的。方法2:   ActiveSheet.Range("A65535").End(xlUp).Row   ActiveSheet.Range("IV1").End(xlToLeft).Column   可以简写为:   ActiveSheet.[A65536].End(xlUp).Row   ActiveSheet.[IV1].End(xlToLeft).Column       缺点:只能计算出一列(行)的最后一个单元格所在的行(列)数。当最后一行或者一列不为空时无法返回正确的结果,而且2007版以后,由于最大行列数增加,兼容性存在问题。本例是只返回A列最后一个单元格所占的行数。方法3:   ActiveSheet.Cells.SpecialCells(xlCellTypeLastCell).Row   ActiveSheet.Cells.SpecialCells(xlCellTypeLastCell).Column   缺点:在工作表进行对删除或清除操作时也会变得比实际情况大。方法4:   ActiveSheet.UsedRange.SpecialCells(xlCellTypeLastCell).Row   ActiveSheet.UsedRange.SpecialCells(xlCellTypeLastCell).Column   缺点:在工作表进行对删除或清除操作时也会变得比实际情况大。方法5:   Application.CountA(ActiveSheet.Range("A:A"))   Application.CountA(ActiveSheet.Range("1:1"))   只能统计一列(行)的实际使用情况,得到的不一定是最后一行(列)的位置。方法2的数值比此方法大时,说明在A列的数据间有空白未填写的单元格。方法6:   ActiveSheet.Cells.Find(What:="*", After:=[A1], SearchOrder:=xlByRows, SearchDirection:=xlPrevious).Row   ActiveSheet.Cells.Find(What:="*", After:=[A1], SearchOrder:=xlByColumns, SearchDirection:=xlPrevious).Column   效果同方法2 以上方法中比较常用的是方法1和方法2。



【本文地址】


今日新闻


推荐新闻


CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3