[按键精灵]说一个可能导致脚本出错误的问题

[按键精灵]说一个可能导致脚本出错误的问题大家好 我是公众号 3 分钟学堂的郭立员 前言不知道大家有没有遇到这种情况 脚本有时候能用 有时候不能用 有的设备能用 有的设备不能用 造成这种情况的一种原因是没有对变量 数组 做空值判断

大家好,欢迎来到IT知识分享网。

大家好,我是公众号3分钟学堂的郭立员~

前言

不知道大家有没有遇到这种情况,脚本有时候能用,有时候不能用,有的设备能用,有的设备不能用。

造成这种情况的一种原因是没有对变量(数组)做空值判断

一、为啥要对变量做空值判断

因为如果不对变量做空值判断可能会导致脚本报错:

①、变量作为比较判断的条件

所谓比较判断就是两个内容比较大小,要求比较双方是同一种类型,当其中一个内容变成空值就会报错。

正常情况:

Dim a = 3 If a > 2 Then TracePrint "判断成立" End If

异常情况

Dim a = "" If a > 2 Then TracePrint "判断成立" End If

当a的值为空值的时候,脚本就会报错:

发生运行时错误!错误代码:2,错误行号:2,错误信息:attempt to compare number with string

从代码结构上来说是没有变化的,唯一变化的是变量a的值,例子中a的是直接定义的,如果a的值来自于读取网络接口,那么如果网络正常时脚本是可以正常运行,如果网络出了问题,a值就是空值,脚本就会报错。

②、怎么判断变量是不是空值

下面说几种写法:

写法一、len判断字符数量

Dim a = "" If Len(a) > 0 Then TracePrint "a不是空值" Else TracePrint "a是空值" End If

写法二、直接判断是否等于空(””)

Dim a = "" If a <> "" Then TracePrint "a不是空值" Else TracePrint "a是空值" End If

写法三、是否是null

Dim a TracePrint IsNull(a) If IsNull(a) Then TracePrint "a是空值" Else TracePrint "a不是空值" End If
Dim a If a = null Then TracePrint "a是空值" Else TracePrint "a不是空值" End If

null和空值的区别我也说不太清楚,感觉是一样,又觉得有什么不同,这里我暂且当它们是一样的了。

二、对数组进行判断

①、数组下标的超限

Dim arr ={{1,2,3},{4,5,6}} TracePrint arr[1][2] TracePrint arr[3][1]

输出结果:

当前脚本第2行:2 当前脚本第3行:发生运行时错误!错误代码:2,错误行号:3,错误信息:attempt to index global 'id' (a null value)

同样是输出数组,但是第二个输出报错了,因为下标超限,因为数字上限是2,但是写了arr[3],超出最大下标了,那么就会报错。

如果下标是变量或者数组中内容数量不确定,当下标超限的时候就会报错,报错信息是数组为空。

类似的情况还有这样的:

Dim arr ={null} TracePrint arr["a"][1]

当数组内容真的为空的时候,提取数组内容就会报错。

②、什么情况会出现数组为空

我们要知道怎么能得到一个数组内容,比如定义一个数组、使用分割命令,使用正则匹配,json转table,某些返回值为table的命令

自定义数组基本就知道数组是不是空。

使用分割命令,使用正则匹配,json转table这些命令的话,如果原始数据是空值或者是错误数据,这些命令转换后就会是空的数组。

常见的就是api接口的返回值,如果接口出错了,会得不到数据或者是报错数据,后面转数组再提取就出现报错。

某些返回值为table的命令,这个不好说,但是如果返回值是table的命令,你要对返回值格外注意,最好做数组非空判断。

③、怎么做数组非空判断

使用len命令判断,如果数量不为0,就不是空数组。

Dim arr ={null} If Len(arr) > 0 Then TracePrint "数组不为空" Else TracePrint "数组为空" End If 

总结

代码没有错误,脚本却时好时坏,这是因为某些数据的异常,我们写脚本的时候未必严谨,像我说的这种非空判断,如果不写的话,会导致变量做比较判断或者数组提取时报错。

还有就是系统原因,有些命令在不同系统上兼容性不好,导致不同使用,这些命令在不同设备上运行的返回值就是不一样的,导致后续的报错脚本不能正常运行。

免责声明:本站所有文章内容,图片,视频等均是来源于用户投稿和互联网及文摘转载整编而成,不代表本站观点,不承担相关法律责任。其著作权各归其原作者或其出版社所有。如发现本站有涉嫌抄袭侵权/违法违规的内容,侵犯到您的权益,请在线联系站长,一经查实,本站将立刻删除。 本文来自网络,若有侵权,请联系删除,如若转载,请注明出处:https://yundeesoft.com/159590.html

(0)
上一篇 2024-11-30 19:33
下一篇 2024-11-30 19:45

相关推荐

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注微信