大家好,欢迎来到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