正则分析——将浮点数点左边的数每三位添加一个逗号
Posted mosquito~
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了正则分析——将浮点数点左边的数每三位添加一个逗号相关的知识,希望对你有一定的参考价值。
之前遇到正则表达式,难的都不愿意分析,总觉得之后碰不到,但是作为个程序员,正则是相当重要的,这里记一下这个例子。
首先正则的一个用法 :(?=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被匹配
以上是关于正则分析——将浮点数点左边的数每三位添加一个逗号的主要内容,如果未能解决你的问题,请参考以下文章
为啥在一串数字中每三位加一个逗号,就像1,234,567.01这样有何作用?
为啥在一串数字中每三位加一个逗号,就像1,234,567.01这样有何作用?