参考:Java DecimalFormat 用法

简介:

DecimalFormat 是 NumberFormat 的一个具体子类,用于格式化十进制数字。

public abstract class Format implements Serializable, Cloneable {}

public abstract class NumberFormat extends Format  {}

public class DecimalFormat extends NumberFormat {}

将数字进行格式化,比如取2位小数,这是最常见的。Java 提供 DecimalFormat 类,帮你用最快的速度将数字格式化。

DecimalFormat 类主要靠 # 和 0 两种占位符号来指定数字长度。

模式中的”#”表示如果该位存在字符,则显示字符,如果不存在,则不显示。

//符号含义:
//        E:表示有几位小数
//        0 一个数字
//        # 一个数字,不包括 0
//        . 小数的分隔符的占位符
//        , 分组分隔符的占位符
//        ; 分隔格式。
//        - 缺省负数前缀。
//        % 乘以 100 和作为百分比显示
//        ? 乘以 1000 和作为千进制货币符显示;用货币符号代替;
//          如果双写,国际货币符号代替。如果出现在一个模式中,用货币十进制分隔符代 替十进制分隔符。
//        X 前缀或后缀中使用的任何其它字符,用来引用前缀或后缀中的特殊字符。

示例:

import java.text.DecimalFormat;


public class TestNumberFormat {

    public static void main(String[] args) {

//圆周率
        System.out.println(Math.PI);//3.141592653589793
//取一位整数
        System.out.println(new DecimalFormat("0").format(Math.PI));//3
//取一位整数和两位小数
        System.out.println(new DecimalFormat("0.00").format(Math.PI));//3.14
//取两位整数和三位小数,整数不足部分以0填补,小数部分最后一位四舍五入。
        System.out.println(new DecimalFormat("00.000").format(Math.PI));// 03.142
//取所有整数部分
        System.out.println(new DecimalFormat("#").format(Math.PI));//3
//以百分比方式计数,并取两位小数
        System.out.println(new DecimalFormat("#.##%").format(Math.PI));//314.16%


//欧拉常数和自然对数的基数
        System.out.println(Math.E);//2.718281828459045
//取一位整数
        System.out.println(new DecimalFormat("0").format(Math.E));//3
//取一位整数和两位小数
        System.out.println(new DecimalFormat("0.00").format(Math.E));//2.72
//取两位整数和三位小数,整数不足部分以0填补,小数部分最后一位四舍五入。
        System.out.println(new DecimalFormat("00.000").format(Math.E));// 02.718
//取所有整数部分
        System.out.println(new DecimalFormat("#").format(Math.E));//3
//以百分比方式计数,并取两位小数
        System.out.println(new DecimalFormat("#.##%").format(Math.E));//271.83%


        long c = 299792458;//光速
//显示为科学计数法,并取五位小数
        System.out.println(new DecimalFormat("#.#####E0").format(c));//2.99792E8
//显示为两位整数的科学计数法,并取四位小数
        System.out.println(new DecimalFormat("00.####E0").format(c));//29.9792E7
//每三位以逗号进行分隔。
        System.out.println(new DecimalFormat(",###").format(c));//299,792,458
//将格式嵌入文本
        System.out.println(new DecimalFormat("光速大小为每秒,###米。").format(c));


        DecimalFormat f1, f2;
        f1 = new DecimalFormat("0.000");
        f2 = new DecimalFormat("#.000");
        System.out.println("带0号的" + f1.format(0.20));//带0号的0.200
        System.out.println("带#的" + f2.format(0.20));//带#的.200

        f1 = new DecimalFormat("0.00");
        f2 = new DecimalFormat("0.##");
        System.out.println("小数点00:" + f1.format(0.2));//小数点00:0.20
        System.out.println("小数点##:" + f2.format(0.2));//小数点##:0.2

        f1 = new DecimalFormat("0.00");
        f2 = new DecimalFormat("##.00");
        System.out.println("00的整数:" + f1.format(22));//00的整数:22.00
        System.out.println("##的整数:" + f2.format(22));//##的整数:22.00


        DecimalFormat df1 = new DecimalFormat("0.0");
        DecimalFormat df2 = new DecimalFormat("#.#");
        DecimalFormat df3 = new DecimalFormat("000.000");
        DecimalFormat df4 = new DecimalFormat("###.###");
        System.out.println(df1.format(12.34));//12.3
        System.out.println(df2.format(12.34));//12.3
        System.out.println(df3.format(12.34));//012.340
        System.out.println(df4.format(12.34));//12.34
    }
}

工具类:

import java.math.BigDecimal;

public class DecimalCalculate {
    /**
     * 由于Java的简单类型不能够精确的对浮点数进行运算,这个工具类提供精
     * 确的浮点数运算,包括加减乘除和四舍五入。
     */
    //默认除法运算精度
    private static final int DEF_DIV_SCALE = 10;

    //这个类不能实例化
    private DecimalCalculate() {
    }

    /**
     * 提供精确的加法运算。
     *
     * @param v1 被加数
     * @param v2 加数
     * @return 两个参数的和
     */
    public static double add(double v1, double v2) {
        BigDecimal b1 = new BigDecimal(Double.toString(v1));
        BigDecimal b2 = new BigDecimal(Double.toString(v2));
        return b1.add(b2).doubleValue();
    }

    /**
     * 提供精确的减法运算。
     *
     * @param v1 被减数
     * @param v2 减数
     * @return 两个参数的差
     */
    public static double sub(double v1, double v2) {
        BigDecimal b1 = new BigDecimal(Double.toString(v1));
        BigDecimal b2 = new BigDecimal(Double.toString(v2));
        return b1.subtract(b2).doubleValue();
    }

    /**
     * 提供精确的乘法运算。
     *
     * @param v1 被乘数
     * @param v2 乘数
     * @return 两个参数的积
     */
    public static double mul(double v1, double v2) {
        BigDecimal b1 = new BigDecimal(Double.toString(v1));
        BigDecimal b2 = new BigDecimal(Double.toString(v2));
        return b1.multiply(b2).doubleValue();
    }

    /**
     * 提供(相对)精确的除法运算,当发生除不尽的情况时,精确到
     * 小数点以后10位,以后的数字四舍五入。
     *
     * @param v1 被除数
     * @param v2 除数
     * @return 两个参数的商
     */
    public static double div(double v1, double v2) {
        return div(v1, v2, DEF_DIV_SCALE);
    }

    /**
     * 提供(相对)精确的除法运算。当发生除不尽的情况时,由scale参数指
     * 定精度,以后的数字四舍五入。
     *
     * @param v1    被除数
     * @param v2    除数
     * @param scale 表示表示需要精确到小数点以后几位。
     * @return 两个参数的商
     */
    public static double div(double v1, double v2, int scale) {
        if (scale < 0) {
            throw new IllegalArgumentException(
                    "The scale must be a positive integer or zero");
        }
        BigDecimal b1 = new BigDecimal(Double.toString(v1));
        BigDecimal b2 = new BigDecimal(Double.toString(v2));
        return b1.divide(b2, scale, BigDecimal.ROUND_HALF_UP).doubleValue();
    }

    /**
     * 提供精确的小数位四舍五入处理。
     *
     * @param v     需要四舍五入的数字
     * @param scale 小数点后保留几位
     * @return 四舍五入后的结果
     */
    public static double round(double v, int scale) {
        if (scale < 0) {
            throw new IllegalArgumentException(
                    "The scale must be a positive integer or zero");
        }
        BigDecimal b = new BigDecimal(Double.toString(v));
        BigDecimal one = new BigDecimal("1");
        return b.divide(one, scale, BigDecimal.ROUND_HALF_UP).doubleValue();
    }

    /**
     * 提供精确的类型转换(Float)
     *
     * @param v 需要被转换的数字
     * @return 返回转换结果
     */
    public static float convertsToFloat(double v) {
        BigDecimal b = new BigDecimal(v);
        return b.floatValue();
    }

    /**
     * 提供精确的类型转换(Int)不进行四舍五入
     *
     * @param v 需要被转换的数字
     * @return 返回转换结果
     */
    public static int convertsToInt(double v) {
        BigDecimal b = new BigDecimal(v);
        return b.intValue();
    }

    /**
     * 提供精确的类型转换(Long)
     *
     * @param v 需要被转换的数字
     * @return 返回转换结果
     */
    public static long convertsToLong(double v) {
        BigDecimal b = new BigDecimal(v);
        return b.longValue();
    }

    /**
     * 返回两个数中大的一个值
     *
     * @param v1 需要被对比的第一个数
     * @param v2 需要被对比的第二个数
     * @return 返回两个数中大的一个值
     */
    public static double returnMax(double v1, double v2) {
        BigDecimal b1 = new BigDecimal(v1);
        BigDecimal b2 = new BigDecimal(v2);
        return b1.max(b2).doubleValue();
    }

    /**
     * 返回两个数中小的一个值
     *
     * @param v1 需要被对比的第一个数
     * @param v2 需要被对比的第二个数
     * @return 返回两个数中小的一个值
     */
    public static double returnMin(double v1, double v2) {
        BigDecimal b1 = new BigDecimal(v1);
        BigDecimal b2 = new BigDecimal(v2);
        return b1.min(b2).doubleValue();
    }

    /**
     * 精确对比两个数字
     *
     * @param v1 需要被对比的第一个数
     * @param v2 需要被对比的第二个数
     * @return 如果两个数一样则返回0,如果第一个数比第二个数大则返回1,反之返回-1
     */
    public static int compareTo(double v1, double v2) {
        BigDecimal b1 = new BigDecimal(v1);
        BigDecimal b2 = new BigDecimal(v2);
        return b1.compareTo(b2);
    }

}

保留位数:

BigDecimal.ROUND_HALF_DOWN : 5去尾,其他四舍五入

BigDecimal.ROUND_HALF_UP : 5进位,其他四舍五入 ,即我们常用的四舍五入

BigDecimal.ROUND_UP : 都进位

BigDecimal.ROUND_DOWN : 都去尾

//保留四位小数测试:
{
    BigDecimal decimal = new BigDecimal("1.12345");
    System.out.println(decimal);
    BigDecimal setScale = decimal.setScale(4,BigDecimal.ROUND_HALF_DOWN);//5去尾,其他四舍五入
    System.out.println(setScale);
    //            1.1234

    BigDecimal setScale1 = decimal.setScale(4,BigDecimal.ROUND_HALF_UP);//5进位,其他四舍五入
    System.out.println(setScale1);
    //            1.1235

    BigDecimal setScale2 = decimal.setScale(4,BigDecimal.ROUND_UP);//都进位
    System.out.println(setScale2);
    //            1.1235

    BigDecimal setScale3 = decimal.setScale(4,BigDecimal.ROUND_DOWN);//都去尾
    System.out.println(setScale3);
    //            1.1234

    /*-------------------------------------------------------------------------------*/

    BigDecimal bigDecimal = new BigDecimal("1.12344");
    System.out.println(bigDecimal);
    BigDecimal setScale4 = bigDecimal.setScale(4,BigDecimal.ROUND_HALF_DOWN);//5去尾,其他四舍五入
    System.out.println(setScale4);
    //            1.1234

    BigDecimal setScale5 = bigDecimal.setScale(4,BigDecimal.ROUND_HALF_UP);//5进位,其他四舍五入
    System.out.println(setScale5);
    //            1.1234

    BigDecimal setScale6 = bigDecimal.setScale(4,BigDecimal.ROUND_UP);//都进位
    System.out.println(setScale6);
    //            1.1235

    BigDecimal setScale7 = bigDecimal.setScale(4,BigDecimal.ROUND_DOWN);//都去尾
    System.out.println(setScale7);
    //            1.1234

    /*-------------------------------------------------------------------------------*/

    BigDecimal bigdecimal = new BigDecimal("1.12346");
    System.out.println(bigdecimal);
    BigDecimal setScale8 = bigdecimal.setScale(4,BigDecimal.ROUND_HALF_DOWN);//5去尾,其他四舍五入
    System.out.println(setScale8);
    //            1.1235

    BigDecimal setScale9 = bigdecimal.setScale(4,BigDecimal.ROUND_HALF_UP);//5进位,其他四舍五入
    System.out.println(setScale9);
    //            1.1235

    BigDecimal setScale10 = bigdecimal.setScale(4,BigDecimal.ROUND_UP);//都进位
    System.out.println(setScale10);
    //            1.1235

    BigDecimal setScale11 = bigdecimal.setScale(4,BigDecimal.ROUND_DOWN);//都去尾
    System.out.println(setScale11);
    //            1.1234
}