当前位置:首页 > 软件开放 > 正文内容

asp.net编写代码方式(aspnet web教程)

软件开放9个月前 (02-06)319

处理运行时错误

可能会用到这些语句

因为执行过程时,总会遇到一些无法预料、无法避免的运行时错误,如激活一个根本不存在的工作表,将一个空单元格设置为除数,将工作表重命名为一个已经存在的名称等,所以无论编写代码时多么认真、仔细,都不能避免在执行过程时发生错误。

然而,有些运行时错误,是可以预先知道它们发生的位置的,对这种预先知道可能发生的错误,可以在过程中加入一些错误处理的代码,以保证过程能正常执行。

在VBA中,通过 On Error语句来获取过程中运行时错误的信息,并对错误进行处理。

如果出错,

让过程跳转到另一行代码处继续执行

如果希望在发生运行时错误时,过程能自动跳转到指定行的代码处继续执行,可以使用代码:

On Error GoTo Line

其中,代码中的“Line”是替 GoTo语句设置的标签。这个语句告诉 VBA,当在“On Error GoTo Line”这行代码之后发生运行时错误时,跳转到标签所在行的位置继续执行过程,如下图所示:

如果活动工作簿中没有标签名称为“Excel”的工作表,那么执行这个过程后,得到的是如图 9 -25 所示的结果。

展开全文

图9-25 使用On Error 语句处理过程中的运行时错误

如果出错,

忽略出错行的代码继续执行

On Error Resume Next是VBA中另一个处理运行时错误的语句。在执行过程时,如果On Error Resume Next之后发生运行时错误,则忽略存在运行时错误的代码,继续执行之后的其他代码。如下图所示:

因为VBA会忽略On Error Resume Next之后所有存在运行时错误的代码,所以执行这个过程后,无论工作簿中是否存在标签名称为“Excel”的工作表,VBA都不会为是否能执行代码 Worksheets("Excel").Select 提示错误信息, Exit Sub也一定会被执行,MsgBox函数所在的代码行将不会得到执行的机会。

注意:在编写过程时,因为只有On Error语句之后发生的运行 时错误才会被捕捉到,所以应该把On Error语句放在可能发生运行时错误的代码之前。

停止对过程中运行时错误的处理

无论是On Error GoTo Line语句,还是On Error Resume Next语句,只要在它们之后的代码发生运行时错误,都会按预先设置好的处理方式执行过程。可是执行过程时真正发生运行时错误的代码,有可能并不是预先估计会出错的那行代码,再使用预设的方式处理错误,未必就是正确的,如下图所示:

此时,如果活动工作簿中存在标签名称为“Excel”的工作表,但没有标签名称为 “ExcelHome”的工作表,执行过程后,得到的是如图 9 - 26 所示的结果。

图9-26 处理过程中存在的运行时错误

很显然,这并不是希望得到的结果。在这个过程中,通过On Error GoTo Er设置的,是当 Worksheets("Excel").Select 执行出错时的处理方式,而在刚才的例子中,发生运行时错误的却是另一行代码。

如果不希望其他代码出错时,也按预设的错误处理方式执行过程,可以在希望处理运行时错误的代码之后,停止对之后代码中可能存在的运行时错误的处理。

要停止对运行时错误的处理,可以使用On Error GoTo 0 语句,在过程中写入了On Error GoTo 0 后,那么无论在这行代码之前做了怎样的设置,之后出现的运行时错误都不会再按之前的设置执行过程,除非之后又通过On Error GoTo Line或On Error Resume Next设置了运行时错误的处理方式,如下图所示:

如果活动工作簿中拥有名为“Excel”的工作表,但没有名为“ExcelHome”的工作表, 则执行过程就会出错,如图 9-27 所示。

图9-27 发生运行时错误的过程

单击对话框中的【调试】按钮,让过程进入中断模式,可以看到过程出错的代码所在行,如图 9- 28 所示。

图9-28 执行过程时出错的代码

如果要处理这行代码可能发生的运行时错误,应重新使用On Error GoTo Line或On Error Resume Next设置,如下图所示:

asp.net编写代码方式(aspnet web教程)

这样,执行过程后就能得到期望的结果了,如图 9 -29 所示。

图9-29 处理过程中出现的运行时错误

处理运行错误的小窍门,你学会了吗?

推荐阅读

北京大学出版社

《别怕,Excel VBA其实很简单》

京东图书 每满100减50

数量有限,手慢无!

扫描二维码推送至手机访问。

版权声明:本文由飞速云SEO网络优化推广发布,如需转载请注明出处。

本文链接:http://muyuzhen.com/post/86015.html

分享给朋友:

“asp.net编写代码方式(aspnet web教程)” 的相关文章

个人简历网页设计思路(个人简历页面设计)

个人简历网页设计思路(个人简历页面设计)

今天给各位分享个人简历网页设计思路的知识,其中也会对个人简历页面设计进行解释,如果能碰巧解决你现在面临的问题,别忘了关注本站,现在开始吧!本文目录一览: 1、Html网页简历如何制作 2、网上求职简历制作技巧 3、求DreamWeaver网页的形式制作一份个人简历 4、如何制作比较炫酷的...

源码编辑器制作大鱼吃小鱼(大鱼吃小鱼游戏制作)

源码编辑器制作大鱼吃小鱼(大鱼吃小鱼游戏制作)

今天给各位分享源码编辑器制作大鱼吃小鱼的知识,其中也会对大鱼吃小鱼游戏制作进行解释,如果能碰巧解决你现在面临的问题,别忘了关注本站,现在开始吧!本文目录一览: 1、是啥意思 2、孢子是一款什么游戏? 3、联想 ThinkPad SL410 笔记本电脑 ,传奇,大鱼吃小鱼之类的游戏不能全屏。...

送真充手游(送真充手游哪个最好玩)

送真充手游(送真充手游哪个最好玩)

今天给各位分享送真充手游的知识,其中也会对送真充手游哪个最好玩进行解释,如果能碰巧解决你现在面临的问题,别忘了关注本站,现在开始吧!本文目录一览: 1、和凡人飞仙传(无限送真充)类似手游有吗? 2、魂斗三国(策划送真充)手游充值有打折吗? 3、和摸金校尉之天字卷(无限送真充)类似手游有吗?...

DAM交易平台(dam交易平台会倒贴钱吗)

DAM交易平台(dam交易平台会倒贴钱吗)

今天给各位分享DAM交易平台的知识,其中也会对dam交易平台会倒贴钱吗进行解释,如果能碰巧解决你现在面临的问题,别忘了关注本站,现在开始吧!本文目录一览: 1、福田DAM16KR发动机参数 2、长安4G15S和DAm15KR发动机哪个好? 3、ops是什么意思? 4、It审计软件知道有哪...

端游游戏交易平台app排行榜(手游交易平台app排行榜)

端游游戏交易平台app排行榜(手游交易平台app排行榜)

今天给各位分享端游游戏交易平台app排行榜的知识,其中也会对手游交易平台app排行榜进行解释,如果能碰巧解决你现在面临的问题,别忘了关注本站,现在开始吧!本文目录一览: 1、手游交易平台哪个好 2、卖游戏账号哪个平台好? 3、手游交易平台哪个好? 4、网络游戏账号交易平台哪个比较好?...

一句话让别人关注你(一句话让别人关注你怎么说)

一句话让别人关注你(一句话让别人关注你怎么说)

本篇文章给大家谈谈一句话让别人关注你,以及一句话让别人关注你怎么说对应的知识点,希望对各位有所帮助,不要忘了收藏本站喔。 本文目录一览: 1、如何一句话让别人关注你? 2、一句话让别人关注你,吸引别人点赞的句子大全 3、8个字让别人关注你 4、一句话让别人关注你 快手涨粉句子 5、一...