码迷,mamicode.com
首页 > 其他好文 > 详细

正则分析——将浮点数点左边的数每三位添加一个逗号

时间:2018-10-23 12:04:47      阅读:209      评论:0      收藏:0      [点我收藏+]

标签:UNC   log   bsp   个数   strong   获取   分析   func   return   

之前遇到正则表达式,难的都不愿意分析,总觉得之后碰不到,但是作为个程序员,正则是相当重要的,这里记一下这个例子。

首先正则的一个用法 :(?=pattern)

正向肯定预查,在任何匹配pattern的字符串开始处匹配查找字符串。
这是一个非获取匹配,也就是说,该匹配不需要获取供以后使用。
例如,“Windows(?=95|98|NT|2000)”能匹配“Windows2000”中的“Windows”,但不能匹配“Windows3.1”中的“Windows”。
预查不消耗字符,也就是说,在一个匹配发生后,在最后一次匹配之后立即开始下一次匹配的搜索,而不是从包含预查的字符之后开始。

代码如下:

function commafy(num) {
    return num && num
        .toString()
        .replace(/(\d)(?=(\d{3})+\.)/g, function ($1, $2, $3) {
            console.log($1, $2, $3);
            return $2 + ‘,‘;
    });
}
console.log(commafy(12345678.11)); 

输出:

技术分享图片

分析:

1.$1, $2, $3分别代表正则匹配的括号里的值

(\d{3})+\.  说明匹配3个及3的倍数个数字加“.”结尾的 如 345678. 或 678.

(\d)(?=(\d{3})+\.   说明只有匹配到该数字后有3个及3的倍数个数字加“.”结尾的该数字被匹配 如 2345678. 的2被匹配 5678. 的5被匹配

正则分析——将浮点数点左边的数每三位添加一个逗号

标签:UNC   log   bsp   个数   strong   获取   分析   func   return   

原文地址:https://www.cnblogs.com/mosquito18/p/9835494.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!