此博客是本人从学生时代开始做笔记所用, 部分是工作所遇问题,做填坑笔记,部分闲来查阅资料,加上自己的理解所总结的学习笔记, 常忙得不可开交,若漏了资料来源,望通知~ 前路漫漫,写点东西告诉自己正在一点点进步,而不要迷失于繁忙。

正则表达式的正向预查

首先,让我们先做一道算法题: 将一串带小数的金额,例如: 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不支持)

posted @ 2017-09-22 14:24  炎泽  阅读(1867)  评论(0)    收藏  举报