zoukankan      html  css  js  c++  java
  • 正则表达式的正向预查

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

  • 相关阅读:
    5/14 补沙
    5/21 购填缝剂
    5/30 购水不漏
    6/1 购防水
    6/4 补防水
    5/21 人工
    5/7 增购电线
    6/2 补防水
    5/4 瓦工进场
    5/31 补瓷砖
  • 原文地址:https://www.cnblogs.com/yanze/p/7574693.html
Copyright © 2011-2022 走看看