package com.lee.test;java
import java.text.DecimalFormat;app
import java.util.Locale;ide
/**spa
* DecimalFormat的幾種用法!.net
* @author leeorm
* @depict NumberFormat.getInstance()方法返回NumberFormat的一個實例(對象
* 其實是NumberFormat具體的一個子類,例如DecimalFormat), 這適合根ci
* 據本地設置格式化一個數字。你也可使用非缺省的地區設置,例如德國。而後格式文檔
* 化方法根據特定的地區規則格式化數字。這個程序也可使用一個簡單的形式:字符串
* NumberFormat.getInstance().format(1234.56)
*/
public class Demo_test {
public static void main(String[] args) {
// for (int i = 1; i <= 100; i++) {
// String squence = new DecimalFormat("00000").format(i);
// System.out.println(squence+",");
// }
// 獲得本地的缺省格式
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補齊。程序的輸出:
DecimalFormat df = new DecimalFormat("0.000E0000");
System.out.println(df.format(1234.56));
}
}
==========================================================================
在作做業的時候不免有些生疏,也許是由於我這堂課沒聽,在查API的時候即便查到了一不定立刻運用自如.因此衝了下浪,哈哈~~~終於發現了條大魚.
NumberFormat.getInstance()方法返回NumberFormat的一個實例(其實是NumberFormat具體的一個子類,例如DecimalFormat), 這適合根據本地設置格式化一個數字。你也可使用非缺省的地區設置,例如德國。而後格式化方法根據特定的地區規則格式化數字。這個程序也可使用一個簡單的形式:NumberFormat.getInstance().format(1234.56)可是保存一個格式而後重用更加有效。國際化是格式化數字時的一個大問題。另外一個是對格式的有效控制,例如指定小數部分的位數,下面是解決這個問題的一個簡單例子: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.5601234,560類似的,也能夠控制指數形式的格式,例如: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對於百分數: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中。例如: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"。第一部分使用本地格式解析,第二部分使用德國格式解析。當程序在美國運行,結果是:1234561234.56換句話說,"1234,56"在美國被認爲是一個巨大的整數"123456"而在德國被認爲是一個小數"1234.56"。3.4. DecimalFormat 和 NumberFormat的聯繫在上面的例子中, DecimalFormat 和 NumberFormat 都被使用了。DecimalFormat 經常使用於得到很好的格式控制,而NumberFormat 經常使用於指定不一樣於本地的地區。如何結合兩個類呢?答案圍繞着這樣的事實:DecimalFormat是NumberFormat的一個子類,其實例被指定爲特定的地區。所以,你可使用NumberFormat.getInstance 指定一個地區,而後將結構強制轉換爲一個DecimalFormat對象。文檔中提到這個技術能夠在大多狀況下適用,可是你須要用try/catch 塊包圍強制轉換以防轉換不能正常工做 (大概在很是不明顯得狀況下使用一個奇異的地區)。下面是一個這樣的例子: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 numberSystem.out.println(df.format(1234.56));}}getInstance() 方法得到格式,而後調用applyPattern()方法設置格式模式,輸出:1234,56000若是你不關心國際化,能夠直接使用DecimalFormat 。其中v 爲未處理的double,scale爲需求精度,返回須要小數位數的doublepublic 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(); }