VBA取得EXCEL表格中的行数和列数

VBA取得EXCEL表格中的行数和列数

请注意不要使用Columus等关键字作为变量,例如"Columus = ActiveSheet.UsedRange.Columns.Count"!

初学EXCEL宏的童鞋,总是很想知道表格中含有数据的行数和列数,尤其是行数和列数不确定的情况下。这样可以避免很多的错误,并且可以提高效率。但每次用到的时候到网上查找时,总是给了很多无用的答案,往往找不到想要的结果。笔者也是每次使用时,临时查找总是很头疼。偶然发现一篇博客,上面详细记录了不同的方法,笔者测试了几种发现真的很好用。本着分享万岁的精神,将博客内容共享出来。希望对大家有所帮助。

来源:http://www.okexcel.com.cn/bbs/viewthread.php?tid=26

注:每种方法中上面的是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

缺点:只能计算出一列(行)的最后一个单元格所在的行(列)数。本例是只返回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。
在这里插入图片描述

在编写VBA代码来统计Word文档中所有表格行数列数时,可以参考《VBAEXCEL中操作WORD表格:计数与属性获取》这一资料。该资料详细介绍了如何操作Word文档的表格,并提供了一种高效的自动化方法。 参考资源链接:[VBAEXCEL中操作WORD表格:计数与属性获取](https://wenku.csdn.net/doc/hcmo8fdoto?spm=1055.2569.3001.10343) 首先,需要在ExcelVBA编辑器中插入一个新模块,并定义必要的Word对象文档对象。使用`Word.Documents.Open`方法打开指定的Word文档,并将Word应用程序的可见性设置为False,以便在后台执行操作。 接下来,通过`ActiveDocument.Tables.Count`获取文档中表格的总数。然后,使用双重循环遍历每个表格,其中外层循环遍历表格,内层循环遍历表格中的每一行。通过`Tables(i).Rows.Count``Tables(i).Columns.Count`分别获取第i个表格行数列数,并将这些信息输出或存储到Excel工作表中。 最后,不要忘记关闭Word文档Word应用程序,释放资源。这一过程可以通过`WordDoc.Close``WordApp.Quit`方法实现,并通过`Set WordDoc = Nothing``Set WordApp = Nothing`清除对对象的引用。 通过以上步骤,你可以得到一个完整的VBA程序,它不仅能够统计Word文档中表格的总数,还能精确计算出每个表格行数列数,极大提高数据处理的效率准确性。 参考资源链接:[VBAEXCEL中操作WORD表格:计数与属性获取](https://wenku.csdn.net/doc/hcmo8fdoto?spm=1055.2569.3001.10343)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值