VBS中InStrRev函數(shù)使用過不少,但是幾乎沒有用過第三個參數(shù),今天才發(fā)現(xiàn)第三個參數(shù)的用法跟我想的不太一樣。
返回某字符串在另一個字符串中出現(xiàn)的從結尾計起的位置。
InStrRev(string1, string2[, start[, compare]])
參數(shù)
string1
必選項。接受搜索的字符串表達式。
string2
必選項。被搜索的字符串表達式。
Start
可選項。數(shù)值表達式,用于設置每次搜索的開始位置。如果省略,則默認值為 -1,表示從最后一個字符的位置開始搜索。如果 start 包含 Null,則出現(xiàn)錯誤
compare
可選項。在計算子字符串時,指示要使用的比較類型的數(shù)值。如果省略,將執(zhí)行二進制比較。有關數(shù)值,請參閱“設置”部分。
第三個參數(shù)用于設置每次搜索的開始位置。如果省略,則默認值為 -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。問題在于第三個參數(shù)不是表示從最后第N個字符的位置開始搜索,而是從開始第N個字符開始搜索。