正则表达式的正向预查

首先,让我们先做一道算法题: 将一串带小数的金额,例如: 1010000.5689, 每3位加上','分隔符。

刚开始我的做法是将.左边的部分单独提取出来进行正则替换,这花费了不少的步骤,直到我发现这种做法:

function commafy(str){
return str.replace(/(d{1,3})(?=(d{3})+.)/g, '$1,')
}
console.log(commafy('1010000.5689'))

其中的?=称为正向预测,也叫正向前瞻

正向预测(?=pattern),即查找一个字符串,该字符串的后边接有符合pattern条件的子字符串,但此pattern为非匹配捕获,即不需要获取以供以后使用

因此 1(第一个1) 后接有010 000,符合条件

0(第二个0) 后接有000 符合条件

此外还有

负向前瞻 (?!pattern) 匹配后面不是pattern的字符串

正向后瞻 (?<=pattern) 匹配前面是pattern的字符串 (js不支持)

负向后瞻 (?<!pattern) 匹配前面不是pattern的字符串 (js不支持)

原文地址:https://www.cnblogs.com/yanze/p/7574693.html