DecimalFormat 的用法

DecimalFormat 是 NumberFormat 的一个具体子类,用于格式化十进制数字。DecimalFormat 包含一个模式 和一组符号 ,在做数字格式化时,DecimalFormat还是比较方便的。常用于保留小数点后几位、数字间用,分割、四舍五入等场合。

关键符号:

0:只要有可能就把数字拉上这个位置,不包括 0

.: 小数的分隔符的占位符

- :缺省负数前缀。

,:分组分隔符的占位符 (只能放在整数部分)

%: 乘以 100 和作为百分比显示,等~~

截取整数部分:

DecimalFormat df = new DecimalFormat("0");

df.setRoundingMode(RoundingMode.HALF_DOWN);

System.out.println(("----------截取整数部分:----------"));

System.out.println((df.format(785.395)));

System.out.println((df.format(456.00)));

System.out.println((df.format(0.342)));

//四舍五入(截取整数):比四小的都舍去,比四大的都进一

System.out.println(("----------还可以四舍五入:----------"));

System.out.println((df.format(785.695)));

System.out.println((df.format(456.70)));

System.out.println((df.format(0.542)));

结果如下:

截取整数部分以及小数点后一位(小数部分为0时,不显示小数):

DecimalFormat df = new DecimalFormat("#.#");

df.setRoundingMode(RoundingMode.HALF_DOWN);

System.out.println(("--------截取整数部分以及小数点后一位:--------"));

System.out.println((df.format(785.395)));

System.out.println((df.format(456.00)));

System.out.println((df.format(0.342)));

结果如下:

以负数形式显示:

DecimalFormat df = new DecimalFormat("-#.#");

df.setRoundingMode(RoundingMode.HALF_DOWN);

System.out.println(("----------以负数形式显示:----------"));

System.out.println((df.format(785.395)));

System.out.println((df.format(456.00)));

System.out.println((df.format(0.342)));

结果如下:

#字符)选择整数部分,以字符串千克结尾:

DecimalFormat df = new DecimalFormat("#千克");

df.setRoundingMode(RoundingMode.HALF_DOWN);

System.out.println(("--------选择整数部分,以字符串千克结尾--------"));

System.out.println((df.format(785.395)));

结果如下:

,#)整数部分每3位用,分隔:

DecimalFormat df = new DecimalFormat(",###");

df.setRoundingMode(RoundingMode.HALF_DOWN);

System.out.println(("----------整数部分每3位用,分隔----------"));

System.out.println((df.format(785210.395)));

结果如下:

百分比显示, 并保留小数点后二位:

double g=Double.valueOf((list.get(i).getSignaMoney()));

double f=Double.valueOf((list.get(i).getYiqi()));

double sum=g/f;

DecimalFormat df=new DecimalFormat("##.##%");

String st=df.format(sum);

list.get(i).setQianyueBiLi((st));

结果如下(签约比例):

  • 3
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值