5種方式將數字轉成千分位


by:王美建 from:http://www.cnblogs.com/wangmeijian

原創文章,轉載請保留署名及出處

盡管離過年還有兩個月之久,春運搶票的戰斗已經打響了,悲劇的是我還沒搶到票,看到某瀏覽器上的數字時,想到一個經典面試題,沒錯,就是數字轉千分位。如將數字87463297轉成87,463,297,方法有很多種,我這里只想到5種。

1、利用正則的零寬度正預測先行斷言(?=exp),名字有點難記,意思是斷言自身出現的位置的后面能匹配表達式exp,對此概念還不明白的可以戳這里,這里不做過多解釋。數字千分位的特點是,第一個逗號后面數字的個數是3的倍數,正則:/(\d{3})+$/;第一個逗號前最多可以有1至3個數字,正則:/\d{1,3}/。加起來就是/\d{1,3}(\d{3})+$/,分隔符要從前往后加,就要將前面的數字“87”替換成“87,”,為什么是87不是874?因為874后面只剩下5位數字,在632后加一個分隔符后,將只剩下97,不符合千分位要求,所以第一個分隔符后面的數字位數必須是3的倍數。要匹配數字87,又要保證87后面數字位數是3的倍數,並且要將匹配的87替換成“87,”,就要用到(?=exp),這里先定義一個變量var str = "87463297";

// 零寬斷言
console.info( str.replace(/\d{1,3}(?=(\d{3})+$)/g,function(s){
    return s+','
}) )

2、利用正則的子項來替換,跟第1種方法類似。

// 子項
console.info( str.replace(/(\d{1,3})(?=(\d{3})+$)/g,function($1){
    return $1=$1+','
}) )

3、先將字符串轉成數組,利用reverse反轉數組后每3個數字后添加一個分隔符“,”,到字符串末尾除外,之后轉回字符串。

// 利用字符串和數組方法
console.info( str.split("").reverse().join("").replace(/(\d{3})+?/g,function(s){
    return s+",";
}).replace(/,$/,"").split("").reverse().join("") )

4、利用while循環拼接字符串每隔3個數字加一個分隔符,首尾不加

// 利用循環拼接字符串每隔3個加一個分隔符
var result="",
    index = 0,
    len = str.length-1;
while(len>=0) {
    index%3===0&&index!==0 ? result+=","+str[len] : result+=str[len];
    len--;
    index++;
};
result=result.split("").reverse().join("");
console.info(result);

5、利用while循環在數組里push分隔符,首尾不加

// 利用while循環在數組里push分隔符
var result="",
    index = 0,
    len = str.length,
    i = len-1,
    arr = str.split("");
 
while(len-index>0){
    len>=index&&len-index!==len && arr.splice(len-index,0,",");
    index+=3;
    i-=4;
};
console.log(arr.join(""));

結語:第1種方法是最簡潔的,性能也是最好的,推薦使用。希望本文對園友有所幫助,附上所有例子的demo如果還有其它更好更方便的方法請告訴我,謝謝!

 

by:王美建 from:http://www.cnblogs.com/wangmeijian 

原創文章,轉載請保留署名及出處


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM