DecimalFormat类的使用

来源:互联网 发布:联通软件下载 编辑:程序博客网 时间:2024/05/22 05:01
DecimalFormat 是 NumberFormat 的一个具体子类,用于格式化十进制数字。该类设计有各种功能,使其能够分析和格式化任意语言环境中的数,包括对西方语言、阿拉伯语和印度语数字的支持。它还支持不同类型的数,包括整数 (123)、定点数 (123.4)、科学记数法表示的数 (1.23E4)、百分数 (12%) 和金额 ($123)。所有这些内容都可以本地化。 

DecimalFormat 包含一个模式 和一组符号 

符号含义: 

符号位置本地化?含义0数字是阿拉伯数字#数字字是阿拉伯数字,如果不存在则显示为空.数字是小数分隔符或货币小数分隔符-数字是减号,数字是分组分隔符E数字是分隔科学计数法中的尾数和指数。在前缀或后缀中无需加引号。;子模式边界是分隔正数和负数子模式%前缀或后缀是乘以 100 并显示为百分数/u2030前缀或后缀是乘以 1000 并显示为千分数¤(/u00A4)前缀或后缀否货币记号,由货币符号替换。如果两个同时出现,则用国际货币符号替换。如果出现在某个模式中,则使用货币小数分隔符,而不使用小数分隔符。'前缀或后缀否用于在前缀或或后缀中为特殊字符加引号,例如 "'#'#" 将 123 格式化为 "#123"。要创建单引号本身,请连续使用两个单引号:"# o''clock"

例子:

[java] view plain copy
  1. DecimalFormat df1 = new DecimalFormat("0.0");   
  2. DecimalFormat df2 = new DecimalFormat("#.#");   
  3. DecimalFormat df3 = new DecimalFormat("000.000");   
  4. DecimalFormat df4 = new DecimalFormat("###.###");   
  5. System.out.println(df1.format(12.34));   
  6. System.out.println(df2.format(12.34));   
  7. System.out.println(df3.format(12.34));   
  8. System.out.println(df4.format(12.34));   
运行结果: 
12.3 
12.3 
012.340 
12.34  

[java] view plain copy
  1. DecimalFormat format = new DecimalFormat("###,####.000");   
  2. System.out.println(format.format(111111123456.1227222));   
  3.   
  4. Locale.setDefault(Locale.US);   
  5. DecimalFormat usFormat = new DecimalFormat("###,###.000");   
  6. System.out.println(usFormat.format(111111123456.1227222));   
  7.   
  8. DecimalFormat addPattenFormat = new DecimalFormat();   
  9. addPattenFormat.applyPattern("##,###.000");   
  10. System.out.println(addPattenFormat.format(111111123456.1227));   
  11.   
  12. DecimalFormat zhiFormat = new DecimalFormat();   
  13. zhiFormat.applyPattern("0.000E0000");   
  14. System.out.println(zhiFormat.format(10000));   
  15. System.out.println(zhiFormat.format(12345678.345));   
  16.   
  17. DecimalFormat percentFormat = new DecimalFormat();   
  18. percentFormat.applyPattern("#0.000%");   
  19. System.out.println(percentFormat.format(0.3052222));   
运行结果 :
1111,1112,3456.123 
111,111,123,456.123 
111,111,123,456.123 
1.000E0004 
1.235E0007 
30.522% 
如果使用具有多个分组字符的模式,则最后一个分隔符和整数结尾之间的间隔才是使用的分组大小。所以 "#,##,###,####" == "######,####" == "##,####,####"。
0 0