我有一個很長的無意義字串,其中每個字元都是數字[0-9]或小寫字母[a-z],如下所示
"0z8b816ne139z1b948bjk50f9498t139gjj90t7tb3509w6h0r7tbp"
我想要一個正規表示式,可以匹配字串中出現超過一次的非連續模式 我希望輸出結果如下所示
粗體部分是匹配的部分
"0z8b816ne139z1b948bjk50f9498t139gjj90t7tb3509w6h0r7 ##p"
P粉7544773252023-09-17 09:59:12
正規表示式:(.. )(?=.*?(\1))
const regex = /(..+)(?=.*?())/gm; // 使用RegExp构造函数的替代语法 // const regex = new RegExp('(..+)(?=.*?(\1))', 'gm') const str = `0z8b816ne139z1b948bjk50f9498t139gjj90t7tb3509w6h0r7tbp `; let m; while ((m = regex.exec(str)) !== null) { // 避免零宽匹配导致无限循环 if (m.index === regex.lastIndex) { regex.lastIndex++; } // 可以通过`m`变量访问结果 m.forEach((match, groupIndex) => { console.log(`找到匹配,第${groupIndex}组:${match}`); }); }