• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    VBS中InStrRev函数的第三个参数(Start)使用注意事项

    VBS中InStrRev函数使用过不少,但是几乎没有用过第三个参数,今天才发现第三个参数的用法跟我想的不太一样。

    文档中是这么描述InStrRev函数的:

    复制代码 代码如下:

    返回某字符串在另一个字符串中出现的从结尾计起的位置。

    InStrRev(string1, string2[, start[, compare]])
    参数

    string1
    必选项。接受搜索的字符串表达式。
    string2
    必选项。被搜索的字符串表达式。
    Start
    可选项。数值表达式,用于设置每次搜索的开始位置。如果省略,则默认值为 -1,表示从最后一个字符的位置开始搜索。如果 start 包含 Null,则出现错误
    compare
    可选项。在计算子字符串时,指示要使用的比较类型的数值。如果省略,将执行二进制比较。有关数值,请参阅“设置”部分。

    第三个参数用于设置每次搜索的开始位置。如果省略,则默认值为 -1,表示从最后一个字符的位置开始搜索。于是我想当然的认为如果不省略(假设为N),则表示从最后第N个字符的位置开始搜索。至于为什么会有这样的思维定势,可能是文档表述不清,也可能是受到了其他语言的影响。

    看一个简单的脚本:

    复制代码 代码如下:

    s = http://jb51.net

    n = InStrRev(s, "jb51")
    WScript.Echo n

    n = InStrRev(s, "jb51", 2)
    WScript.Echo n


    第一次输出8,这没有问题;而第二次居然输出0,表示没有找到字符串jb51。问题在于第三个参数不是表示从最后第N个字符的位置开始搜索,而是从开始第N个字符开始搜索。

    所以InStrRev(s, "jb51", 2)相当于InStrRev(Left(s, 2), "jb51"),当然是搜索不到的。

    顺便说一下中文文档里对最后一个参数的描述是错误的:

    compare 参数可以有以下值:

    vbBinaryCompare 执行二进制比较。

    vbDatabaseCompare 执行基于包含在数据库(在此数据库中执行比较)中的信息的比较。

    正确的是vbBinaryCompare和vbTextCompare,所以尽量看英文文档,虽然其中的错误也不少。

    您可能感兴趣的文章:
    • VBS教程:函数-InStrRev 函数
    上一篇:vbs 自制数字益智游戏实现代码
    下一篇:BAT批处理、VBScript批量安装字体脚本分享
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

    VBS中InStrRev函数的第三个参数(Start)使用注意事项 VBS,中,InStrRev,函数,的,第,