作者: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。

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

  1. 【VBA研究】再论取EXCEL有效行列数方法

    作者:iamlaosong 1.我有一个工具,Excel2003格式,因处理数据超过65536条,所以让用户另存为xlsm格式,结果用不了,仔细检查发现问题出在取EXCEL有效行数语句上,该语句如下: ...

  2. 【Python】Python转化dbf文件为Excel,获取Excel最大行列数

    文章目录 将dbf转化为Excel文件(代码完整) 可行方案 网上找的不可行方案 安装win32com Python 写Excel 读取Excel行数,列数 读取Excel最大行数 openpyxl不 ...

  3. 【VBA研究】VBA中如何用求和函数SUM求和

    作者:iamlaosong SUM是Excel的函数,在VBA中调用需要加上Application.WorksheetFunction.Sum(),但是,Excel写法却不能用. 比如,excel单元 ...

  4. VBA简单实现两个Excel文件的比较方法

    到财务走了一圈,正好看到一位同事正在对两个Excel文件进行比较.两个文件的内容大致如此(列出部分列名): 主贷身份证 主贷人 贷款余额 440602**** 李*瑜 ¥35,000 360102** ...

  5. 【VBA研究】VBA编程产生不重复随机数

    作者:iamlasong VBA编程实现不重复随机数输出.VBA里的随机函数是RND,在工作表中随机函数是RAND,一字之差,可要记好了.RND取值范围是[0,1),意思是0和1之间的一个随机数,包含 ...

  6. VBA获取数据区域的行列数

    VBA获取数据区域的行列数 方法1 方法2 方法1 ActiveSheet.UsedRange.Rows.Count ActiveSheet.UsedRange.Columns.Count 缺点:把最 ...

  7. 在VBA编程中巧用EXCEL模板生成样式可变报表

    本文测试文档下载地址:百度文库 随着义教均衡发展工作的稳步推进,要求学校功能室实行规范化管理.若有报废或新增等仪器设备变动,则必须重新制作柜签等报表.Excel是微软公司Microsoft offic ...

  8. 再见 VBA!神器工具统一 Excel 和 Python

    作者 | 东哥起飞 来源 | Python数据科学 经常给大家推荐好用的数据分析工具,也收到了铁子们的各种好评.这次也不例外,我要再推荐一个,而且是个爆款神器. Excel和Jupyter Noteb ...

  9. 零售分析用vba还是python_数据分析?Excel、VBA和Python?营销套路还是大势所趋!...

    "添加关注,方便我们每天向您推送精彩资讯. 扫码申请加Excel微信群 交流心得 解决问题 验证信息:Excel 不懂业务的数据分析都是耍流氓-- 可是只懂业务却不会使用工具的话,效率低下只 ...

最新文章

  1. javascript自动跳转
  2. 5类6类7类网线对比_未来值得投资的6类苗木,5年内市场前景应该都不错!
  3. 工业大数据分析综述:模型与算法
  4. pythonqt4上位机开发_上位机开发之单片机通信实践(一)
  5. 【Python】eval+random库+字符串转列表+列表转字符串
  6. 华为综合测评是什么_喝水不用等待,温度随心控随时喝到热水,测评华为智选恒温电水壶...
  7. TeeChart Pro VCL/FMX教程(六):使用系列(二)
  8. mysql计算指定的时间TPS
  9. 用结构化思维策划一个会议
  10. 如何画出一张合格的技术架构图?
  11. hwaddr和macaddr的区别
  12. Sematic UI框架的学习-button样式(2)
  13. 【离散数学】命题逻辑 带你快速学完离散数学
  14. Python 抽扑克牌游戏
  15. 中亦安图oracle培训,【中亦安图】Systemstate Dump分析经典案例(8)
  16. 为什么快捷指令无法将媒体转换为文本_电脑端“快捷指令”——自动化神器Quicker了解一下...
  17. 盘点5月份GitHub上最热门的开源项目
  18. 使用容联云Celery异步发送短信验证码
  19. 新手入坑编程,奥利给
  20. git clone时提示,git remote: HTTP Basic: Access denied 错误

热门文章

  1. linux 磁盘崩溃,Ubuntu分区不对导致的系统崩溃
  2. 快速排序三种实现方式及其优化
  3. usb dac Linux免驱,飞傲播放器系列USB DAC全新专用驱动玩法攻略
  4. NFS网络文件系统共享日志
  5. 要做中国的GE,富士康工业互联网做得怎么样?
  6. miniPCIe标准
  7. 1、某班期末考试科目为数学(MT)、英语(EN)和物理(PH),有最多不超过30人参加考试。考试后要求:(1)计算每个学生的总分和平均分;(2)按总分成绩由高到低排出成绩的名次;(3)打印出名
  8. 银行承兑汇票贴现费率是多少
  9. UDK:UDK 常用快捷键
  10. uniapp如何开启短震动、触感反馈实现