Excel精英培训网

 找回密码
 注册
数据透视表40+个常用小技巧,让你一次学会!
查看: 3802|回复: 10

[VBA] 004-程序出错原因-疑难千寻千解丛书(VBA)

[复制链接]
发表于 2011-1-7 16:09 | 显示全部楼层 |阅读模式
ET疑难千寻千解丛书之EXCEL2010编程与实践
罗刚君 章兰新 黄朝阳 编著

疑难4
程序出错有哪些原因
程序在运行前或者运行时都可能会出错,那么程序出错有哪些常见的原因呢?
è解决方案
本例专注于程序出错的理论分析,辅助简单案例进行讲解。读者在编写代码时可以从文中提到的几个方面检查自己的代码是否存在疏漏。
í操作方法
常见错误分析
程序出错包括编译错误和运行时错误。常见的编译错误包括命名错误、拼写错误、语法错误(不完整)、参数不完整。
下图所示属于过程名称错误,Sub过程名、Function名及Names的名称不能以数字开始:


下图所示则是方法“Shell”的拼写有误,多了一个“l”:
下图所示属于IF…End IF语句缺少结束语句所致:
下图所示属于参数不完整,DateSerial函数有三个必需参数,缺一不可。另一个比较常见的编译错误是“二义性的名称”,它表示模块中存在多个同名的过程,手工重命名Sub过程名或者Function过程名即可:
                  
运行时错误种类相当多,其中最常见的是代码中的值超过了允许的范围。例如工作簿中仅仅有3个工作表时调用“Sheets(4)”,则产生“下标越界错误”;而下所示对行高的赋值超过了允许的范围0409:
下图所示的单元格列坐标105超过了允许的最大值16384:
下图所示是因为变量赋值时超过了Byte型的有效范围0255:
而下所示则因为名称的引用超过了1255范围而出错,同类的还有数据有效性的公式引用表达式不能超过255个字符,一次创建工作表不能超过255个,字体大小只能在1409,字体颜色ColorIndex只能在056等:
对于Open方法打开不存在的文件名也属于超出范围,保存文件到不存在的磁盘等都可以算超过有效范围,在代码中需要加入判断才能防错。              
另外比较常见的还有“被零除”错误。例如下所示为C20时就会出错:
而下所示为a2:a9没有数值时仍然是因零除数而出错:
=============================
上摘自《EXCEL2010编程与实践》

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有帐号?注册

x
 楼主| 发表于 2011-1-7 16:09 | 显示全部楼层
妖言:

这个内容真好,下次再有人问我代码出错了怎么回事,我就把这个贴的地址砸过去,PS,砸晕砸死概不负责!
{:051:}
回复

使用道具 举报

发表于 2011-1-7 16:26 | 显示全部楼层
回复

使用道具 举报

发表于 2011-1-9 14:31 | 显示全部楼层
谢谢小妖老师
回复

使用道具 举报

发表于 2011-1-11 16:42 | 显示全部楼层
{:35:}{:35:}
回复

使用道具 举报

发表于 2011-1-11 16:43 | 显示全部楼层
谢谢小妖老师的分享{:18:}
回复

使用道具 举报

发表于 2011-1-11 17:58 | 显示全部楼层
升级好难啊,支持一下
回复

使用道具 举报

发表于 2011-1-11 23:09 | 显示全部楼层
进来学习学习~
回复

使用道具 举报

发表于 2011-1-11 23:14 | 显示全部楼层
{:101:}{:101:}{:101:}
回复

使用道具 举报

发表于 2011-1-12 07:50 | 显示全部楼层
学习了 谢谢
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则

小黑屋|手机版|Archiver|Excel精英培训 ( 豫ICP备11015029号 )

GMT+8, 2024-6-7 13:34 , Processed in 0.497952 second(s), 7 queries , Gzip On, Yac On.

Powered by Discuz! X3.4

Copyright © 2001-2020, Tencent Cloud.

快速回复 返回顶部 返回列表