VBS中InStrRev函數使用過不少,但是幾乎沒有用過第三個參數,今天才發現第三個參數的用法跟我想的不太一樣。
文檔中是這么描述InStrRev函數的:
第三個參數用于設置每次搜索的開始位置。如果省略,則默認值為 -1,表示從最后一個字符的位置開始搜索。于是我想當然的認為如果不省略(假設為N),則表示從最后第N個字符的位置開始搜索。至于為什么會有這樣的思維定勢,可能是文檔表述不清,也可能是受到了其他語言的影響。
看一個簡單的腳本:
第一次輸出8,這沒有問題;而第二次居然輸出0,表示沒有找到字符串jb51。問題在于第三個參數不是表示從最后第N個字符的位置開始搜索,而是從開始第N個字符開始搜索。
所以InStrRev(s, "jb51", 2)相當于InStrRev(Left(s, 2), "jb51"),當然是搜索不到的。
順便說一下中文文檔里對最后一個參數的描述是錯誤的:
compare 參數可以有以下值:
vbBinaryCompare 執行二進制比較。
vbDatabaseCompare 執行基于包含在數據庫(在此數據庫中執行比較)中的信息的比較。
正確的是vbBinaryCompare和vbTextCompare,所以盡量看英文文檔,雖然其中的錯誤也不少。
新聞熱點
疑難解答
圖片精選