例如字串 1212121212121212121212
需要配對連續出現5個12或連續出現5個21都算符合條件
匹配個數應該是13個,如下圖,紅色線的代表符合的。
#
曾经蜡笔没有小新2017-07-05 10:00:15
考慮不佔位提取,使用環視提取子分組:(?=.*?((12|21)2{4}))
demo連結:http://regex.zjmainstay.cn/r/...
大家讲道理2017-07-05 10:00:15
>>> import re
>>> ss='1212121212121212121212'
>>> re.findall(r'(?=((12|21){4}))',ss)
[('1212121212', '12'), ('2121212121', '21'), ('1212121212', '12'), ('2121212121', '21'), ('1212121212', '12'), ('2121212121', '21'), ('1212121212', '12'), ('2121212121', '21'), ('1212121212', '12'), ('2121212121', '21'), ('1212121212', '12'), ('2121212121', '21'), ('1212121212', '12')]
js的Re引擎有點粗糙,需要循環回傳子匹配。
var str="1212121212121212121212";
var pattern=/(?=((12|21){4}))/g;
while(m = pattern.exec(str)){
console.log(m[1])
pattern.lastIndex++ //由于没有消耗字符,js的Re引擎不会递增索引。
}