NumberFormat.getInstance()方法返回NumberFormat的一个实例(实际上是NumberFormat具体的一个子类,例如DecimalFormat), 这适合根据本地设置格式化一个数字。你也可以使用非缺省的地区设置,例如德国。然后格式化方法根据特定的地区规则格式化数字。这个程序也可以使用一个简单的形式:
1
|
NumberFormat.getInstance().format( 1234.56 ) |
但是保存一个格式然后重用更加有效。国际化是格式化数字时的一个大问题。
另一个是对格式的有效控制,例如指定小数部分的位数,下面是解决这个问题的一个简单例子:
1
2
3
4
5
6
7
8
9
10
11
12
13
|
import java.text.DecimalFormat; import java.util.Locale; public class DecimalFormat2 { public static void main(String args[]) { // 得到本地的缺省格式 DecimalFormat df1 = new DecimalFormat( "####.000" ); System.out.println(df1.format( 1234.56 )); // 得到德国的格式 Locale.setDefault(Locale.GERMAN); DecimalFormat df2 = new DecimalFormat( "####.000" ); System.out.println(df2.format( 1234.56 )); } } |
在这个例子中设置了数字的格式,使用像"####.000"的符号。这个模式意味着在小数点前有四个数字,如果不够就空着,小数点后有三位数字,不足用0补齐。程序的输出:
1234.560
1234,560
相似的,也可以控制指数形式的格式,例如:
1
2
3
4
5
6
7
|
import java.text.DecimalFormat; public class DecimalFormat3 { public static void main(String args[]) { DecimalFormat df = new DecimalFormat( "0.000E0000" ); System.out.println(df.format( 1234.56 )); } } |
输出:
1.235E0003
对于百分数:
1
2
3
4
5
6
7
|
import java.text.NumberFormat; public class DecimalFormat4 { public static void main(String args[]) { NumberFormat nf = NumberFormat.getPercentInstance(); System.out.println(nf.format( 0.47 )); } } |
输出:
47%
至此,你已经看到了格式化数字的几个不同的技术。另一方面,如何读取并解析包含格式化的数字的字符串?解析支持包含在NumberFormat中。例如:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
|
import java.util.Locale; import java.text.NumberFormat; import java.text.ParseException; public class DecimalFormat5 { public static void main(String args[]) { // 本地格式 NumberFormat nf1 = NumberFormat.getInstance(); Object obj1 = null ; // 基于格式的解析 try { obj1 = nf1.parse( "1234,56" ); } catch (ParseException e1) { System.err.println(e1); } System.out.println(obj1); // 德国格式 NumberFormat nf2 =NumberFormat.getInstance(Locale.GERMAN); Object obj2 = null ; // 基于格式的解析 try { obj2 = nf2.parse( "1234,56" ); } catch (ParseException e2) { System.err.println(e2); } System.out.println(obj2); } } |
这个例子分两部分,都是解析一个字符串:"1234,56"。第一部分使用本地格式解析,第二部分使用德国格式解析。当程序在美国运行,结果是:
123456
1234.56
换句话说,"1234,56"在美国被认为是一个巨大的整数"123456"而在德国被认为是一个小数"1234.56"。
DecimalFormat 和NumberFormat的联系
在上面的例子中, DecimalFormat 和 NumberFormat 都被使用了。DecimalFormat 常用于获得很好的格式控制,而NumberFormat 常用于指定不同于本地的地区。如何结合两个类呢?
答案围绕着这样的事实:DecimalFormat是NumberFormat的一个子类,其实例被指定为特定的地区。因此,你可以使用NumberFormat.getInstance 指定一个地区,然后将结构强制转换为一个DecimalFormat对象。文档中提到这个技术可以在大多情况下适用,但是你需要用try/catch 块包围强制转换以防转换不能正常工作 (大概在非常不明显得情况下使用一个奇异的地区)。下面是一个这样的例子:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
|
import java.text.DecimalFormat; import java.text.NumberFormat; import java.util.Locale; public class DecimalFormat6 { public static void main(String args[]) { DecimalFormat df = null ; // 得到一个NumberFormat 对象并 // 强制转换为一个 DecimalFormat 对象 try { df = (DecimalFormat)NumberFormat.getInstance(Locale.GERMAN); } catch (ClassCastException e) { System.err.println(e); } // 设置格式模式 df.applyPattern( "####.00000" ); // format a number System.out.println(df.format( 1234.56 )); } } |
getInstance() 方法获得格式,然后调用applyPattern()方法设置格式模式,输出:
1234,56000
如果你不关心国际化,可以直接使用DecimalFormat 。
其中v 为未处理的double,scale为需求精度,返回需要小数位数的double
1
2
3
4
5
6
7
8
9
|
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(); } |
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。
原文链接:http://blog.csdn.net/JAVA_96/article/details/53556465