首頁»WEB綜合»可以用在 VS Code 中的正則表達式小技巧

可以用在 VS Code 中的正則表達式小技巧

來源:瘋狂的技術宅 發布時間:2019-05-15 閱讀次數:

  你是不是一直都想學正則表達式,但是因為它的復雜性而被推遲了?在本文中,我將向你展示五個易于學習的正則技巧,你可以立即在自己喜歡的文本編輯器中使用它們。

  文本編輯器設置

  雖然現在幾乎所有的文本編輯器都支持正則表達式,但我在本教程中用的是 Visual Studio Code,不過你可以使用任何你喜歡的編輯器。另請注意,你通常需要在搜索輸入框附近的某處打開 RegEx 開關。以下是在 VS Code 中執行此操作的方法:

  你需要通過選中此選項啟用RegEx

  1) .? — ?匹配任何字符

  讓我們開始吧。點符號 . 用來匹配任何字符:

b.t

  上面的正則匹配 "bot",`"bat"和任何以b開頭、t結尾的三個字符的單詞。但是如果你想搜索點符號,則需要用 \ 來對它進行轉義,所以下面這個正則只匹配確切的文本 "b.t":

b\.t

  2) .* ?—? 匹配任何東西

  這里 . 表示“任何字符”, * 表示“此符號重復前面那個內容任何次數。” 把它們放在一起(.*)表示“任何符號重復任意次數。” 例如,你可以用它來查找以某些文本開頭或結尾的匹配項。假設我們有一個這樣的 javascript 方法:

loadScript(scriptName: string, pathToFile: string)

  我們想找到這個方法的所有調用,其中 pathToFile 指向文件夾“lua” 中的任何文件。可以使用以下正則表達式:

loadScript.*lua

  這意味著,“匹配所有以 "loadScript" 開始同時以"lua"結束的字符串。”

  3) ? ?— ?非貪婪的匹配

  .* 之后的 ? 符號和其他一些匹配規則意味著“盡可能少的匹配”。 在上一張圖中,每次匹配都會得到兩次 "lua"字符串,直到第二個 "lua" 所有東西才能全部匹配完畢。如果你想匹配第一次出現的"lua",可以使用以下正則:

loadScript.*?lua

  這意味著,“匹配所有以 "loadScript"開頭,后面為任意字符,直到第一次出現"lua"

  loadScript.*?lua:匹配以 loadScript 開頭的所有內容,直到第一次出現"lua"

  4) `( ) ### ?— 捕獲組和反向引用

  好的,現在我們可以匹配一些文字了。但是如果想要修改我們發現的部分文本呢?這時候就要用到捕獲組。

  假設我們修改了 loadScript 方法,現在需要在它原來的兩個參數之間插入另外一個參數。讓我們把這個新參數命名為 id,這時新的函數原型應如下所示:loadScript(scriptName,id,pathToFile)。我們在這里不能用文本編輯器的常規替換功能,不過正則表達式能夠幫助我們。

  通過上圖你可以看到運行以下正則表達式的結果:

loadScript\(.*?,.*?\)

  這意味著:“匹配以 "loadScript(" 開頭的, 后面跟任意內容,直到遇到第一個, ,然后是任意內容,直到第一個)”

  對你來說,可能看唯一起來比較奇怪的是 \ 符號。它們用于對括號進行轉義。

  因為符號 (和) 是正則表達式用來捕獲匹配文本部分的特殊字符,但我們需要匹配實際的括號字符,所以需要對它們進行轉義。

  在前面的表達式中,我們使用.*?符號定義了方法調用的兩個參數。要使每個參數作為單獨的捕獲組,需要在它們的前后分別添加(和)符號:

loadScript\((.*?),(.*?)\)

  如果你運行這段正則,你將看到沒有任何變化。這是因為它匹配的是相同的文本。但現在我們可以將第一個參數稱為\$1,將第二個參數稱為\$2。這稱為反向引用,它將幫助我們做自己想要的事情:在兩個參數中間添加另一個參數:

  搜索輸入:

loadScript\((.*?),(.*?)\)

  這與之前的正則相同,但分別將參數映射到倒了捕獲組1和2。

  替換輸入:

loadScript($1,id,$2)

  這意味著“用文本"loadScript("、捕獲組1、"id"、捕獲組2和 ) 替換每個匹配的文本 ”。請注意,你不需要在替換輸入中轉義括號。

  5) [ ] ?—? 字符類

  你可以在 [ 和 ] 符號內來列出要在特定位置匹配的字符。例如,[0-9]匹配從0到9的所有數字。你還可以明確列出所有數字:[0123456789] —— 與前面的含義相同。你也可以使用帶字母的破折號,[a-z] 將匹配所有小寫拉丁字符,[A-Z] 將匹配所有大寫拉丁字符,[a-zA-Z] 將會匹配兩者。

  你也可以在字符類之后使用 *,就像在 . 之后一樣,在這種情況下意味著:“匹配此類中任意數量的字符”

  后記

  你應該知道有幾種正則表達式的寫法。我在這里討論的是 javascript RegEx 引擎。大多數現代引擎都很相似,但也可能會存在一些差異。通常這些差異包括轉義字符和反向引用標記。

  你現在就可以打開文本編輯器,立即開始使用其中的一些技巧。你將看到可以比以前更快地完成許多重構任務。一旦你掌握了這些技巧,就可以開始研究更多的正則表達式了

QQ群:WEB開發者官方群(515171538),驗證消息:10000
微信群:加小編微信 849023636 邀請您加入,驗證消息:10000
提示:更多精彩內容關注微信公眾號:全棧開發者中心(fsder-com)
網友評論(共0條評論) 正在載入評論......
理智評論文明上網,拒絕惡意謾罵 發表評論 / 共0條評論
登錄會員中心
湖北快3今天的开奖结果