参考: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
}