了解正規表示式的重疊字串符合
在某些情況下,帶有全域標誌的string#match 方法可能無法匹配重疊序列輸入字串。例如,考慮字串“12345”。使用正規表示式 /d{3}/g,我們預期會得到三個符合項:["123", "234", "345"]。然而,我們只得到一個匹配,「123」。
這是因為 string#match 方法消耗(即讀取並前進其索引過去)匹配的字元。因此,在匹配“123”後,當前索引指向“4”,並且正規表示式引擎停止,不再找到任何匹配項。
使用零寬度斷言解決重疊匹配
為了解決此限制,一種流行的技術涉及使用帶有捕獲組的正向先行斷言。這種方法斷言子字串的存在而不實際消耗它。透過重複測試輸入字串中的所有位置,我們可以捕獲所需的重疊匹配。
var re = /(?=(\d{3}))/g; console.log(Array.from('12345'.matchAll(re), x => x[1]);
在此範例中,我們建立一個具有正向先行斷言的正規表示式,該表達式會擷取三個連續數字而不消耗它們。透過使用 matchAll 迭代輸入字串,我們獲得所需的匹配列表:["123", "234", "345"]。
各種程式語言都支援此技術,使開發人員能夠處理輕鬆重疊字串匹配場景。
以上是如何使用正規表示式來尋找字串中的重疊匹配項?的詳細內容。更多資訊請關注PHP中文網其他相關文章!