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