zoukankan      html  css  js  c++  java
  • 数字格式化,从右往左每隔三位加逗号的四种方法

    转载自:http://www.uedsc.com/micrometer-method.html

    有時候我个必需将数字加上每三个位数加上一个逗号,例如20000变成20,000,目的是为了在方便财务上阅读,所以我整理了以下四种解決的方法:

    1、javascript

    //一个迂回函式
    function formatNumber(str) {
        if(str.length <= 3){
            return str;
        } else {
            return formatNumber(str.substr(0,str.length-3))+','+str.substr(str.length-3);
        }
    }
    //測試函式(注意數字要以字串輸入)
    var money = formatNumber('1234567890');
    alert(money);
    //輸出結果為:1,234,567,890
    View Code

    2、php内置函数

    //測試函式
    $number = 1234567890;
    echo number_format($number, 3, ',' ,'');
    //輸出結果為:1,234,567,890
    View Code

    3、php自定义函数

    function num_format($num){
    if(!is_numeric($num)){
    return false;
    }
    $rvalue='';
    $num = explode('.',$num);//把整数和小数分开
    $rl = !isset($num['1']) ? '' : $num['1'];//小数部分的值
    $j = strlen($num[0]) % 3;//整数有多少位
    $sl = substr($num[0], 0, $j);//前面不满三位的数取出来
    $sr = substr($num[0], $j);//后面的满三位的数取出来
    $i = 0;
    while($i <= strlen($sr)){
    $rvalue = $rvalue.','.substr($sr, $i, 3);//三位三位取出再合并,按逗号隔开
    $i = $i + 3;
    }
    $rvalue = $sl.$rvalue;
    $rvalue = substr($rvalue,0,strlen($rvalue)-1);//去掉最后一个逗号
    $rvalue = explode(',',$rvalue);//分解成数组
    if($rvalue[0]==0){
    array_shift($rvalue);//如果第一个元素为0,删除第一个元素
    }
    $rv = $rvalue[0];//前面不满三位的数
    for($i = 1; $i < count($rvalue); $i++){
    $rv = $rv.','.$rvalue[$i];
    }
    if(!empty($rl)){
    $rvalue = $rv.'.'.$rl;//小数不为空,整数和小数合并
    }else{
    $rvalue = $rv;//小数为空,只有整数
    }
    return $rvalue;
    }
    echo num_format('1234576');
    ?>
    输出1,234,576
    View Code

    4、在執行SQL查詢時,就先將數字進行轉換動作

    --假設表單salary(薪水)有一個名稱為money(錢)的欄位
    SELECT FORMAT(money, 4) FROM salary;
    --輸出結果將會把money的數字資料態轉為xx,xxx,xxx格式,以下為範圍輸出
    SELECT FORMAT(12332.123456, 4);
    --輸出結果為:12,332.1235
    SELECT FORMAT(12332.2,0)
    --輸出結果為:12,332
    SELECT FORMAT(12332.1,4)
    --輸出結果為:12,332.1000
    View Code
  • 相关阅读:
    Eclipse Plugin for Hadoop
    Hadoop伪分布模式配置
    Hadoop单机模式配置
    20180711-Java Number类
    20180711-Java分支结构 – if…else/switch
    20180709-Java循环结构
    20180708-Java运算符
    20180708-Java修饰符
    20180708-Java变量类型
    20180705-Java对象和类
  • 原文地址:https://www.cnblogs.com/lpshan/p/4392933.html
Copyright © 2011-2022 走看看