java DecimalFormat类

转载:http://www.cnblogs.com/xiohao/archive/2013/07/11/3183186.html


今天去面试了,需要上机做题。题目的内容是计算一个货物订单的税费和总价格(包括税费),结果需要精确到两个小数,同时按照如下规则进行处理:

      3.01 ——>3.05,

      2.48——>2.50,

      2.14——>2.15。

      上机的时候不能上网,没有API,但是你可以查源码。这个题目有三个用例测试,而且你的运行结果必须和答案完全相等,你才能获得success。

      当我做到对数据格式化的时候,我卡住了。我只记得NumberFormat类,但是不知在哪个包里,简直就是悲剧啊!

      回来上网查了一篇文章,写的还可以。我就黏贴过来啦。

import java.text.DecimalFormat;
public class DoubleFormate {
 public static void main(String[] args) {
  java.text.DecimalFormat df=new java.text.DecimalFormat("0.00");//保留2位小数
  double d1=123456789.123456;
  double d2=987654321.987654321;
  
  System.out.println("format1_d1="+df.format(d1));//输出format1_d1=123456789.12
  System.out.println("format1_d2="+df.format(d2));//format1_d2=987654321.99  四舍五入
  
  DecimalFormat dff = new DecimalFormat("#,##0.00");
  System.out.println("format2_d1="+dff.format(d1));//输出:format2_d1=123,456,789.12
  System.out.println("format2_d2="+dff.format(d2));//输出:format2_d2=987,654,321.99 四舍五入
 }
}
 
主要使用的类:java.text.DecimalFormat
1。实例化对象,可以用如下两种方法:
DecimalFormat df=(DecimalFormat)NumberFormat.getInstance();
DecimalFormat df1=(DecimalFormat) DecimalFormat.getInstance();
因为DecimalFormat继承自NumberFormat。
2。设定小数位数
系统默认小数位数为3,如:
DecimalFormat df=(DecimalFormat)NumberFormat.getInstance();
System.out.println(df.format(12.3456789));
输出:12.346
现在可以通过如下方法把小数为设为两位:
df.setMaximumFractionDigits(2);
System.out.println(df.format(12.3456789));
则输出为:12.35
3。将数字转化为百分比输出,有如下两种方法:
(1)
df.applyPattern("##.##%");
System.out.println(df.format(12.3456789));
System.out.println(df.format(1));
System.out.println(df.format(0.015));
输出分别为:1234.57% 100% 1.5%
(2)
df.setMaximumFractionDigits(2);
System.out.println(df.format(12.3456789*100)+"%");
System.out.println(df.format(1*100)+"%");
System.out.println(df.format(0.015*100)+"%");
输出分别为:
1,234.57% 100% 1.5%
4。设置分组大小
DecimalFormat df1=(DecimalFormat) DecimalFormat.getInstance();
df1.setGroupingSize(2);
System.out.println(df1.format(123456789));
输出:1,23,45,67,89
还可以通过df1.setGroupingUsed(false);来禁用分组设置,如:
DecimalFormat df1=(DecimalFormat) DecimalFormat.getInstance();
df1.setGroupingSize(2);
df1.setGroupingUsed(false);
System.out.println(df1.format(123456789));
输出:123456789
5。设置小数为必须为2位
DecimalFormat df2=(DecimalFormat) DecimalFormat.getInstance();
df2.applyPattern("0.00");
System.out.println(df2.format(1.2))


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值