欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

java 格式化輸出數(shù)字的方法

 更新時間:2014年01月19日 13:14:03   作者:  
在實際工作中,常常需要設(shè)定數(shù)字的輸出格式,如以百分比的形式輸出,或者設(shè)定小數(shù)位數(shù)等,現(xiàn)稍微總結(jié)如下

主要使用的類:java.text.DecimalFormat

  1。實例化對象,可以用如下兩種方法:

復制代碼 代碼如下:

  DecimalFormat df=(DecimalFormat)NumberFormat.getInstance();
  DecimalFormat df1=(DecimalFormat) DecimalFormat.getInstance();

  因為DecimalFormat繼承自NumberFormat。

  2。設(shè)定小數(shù)位數(shù)

  系統(tǒng)默認小數(shù)位數(shù)為3,如:

復制代碼 代碼如下:

  DecimalFormat df=(DecimalFormat)NumberFormat.getInstance();
  System.out.println(df.format(12.3456789));

  輸出:12.346

  現(xiàn)在可以通過如下方法把小數(shù)為設(shè)為兩位:

復制代碼 代碼如下:

  df.setMaximumFractionDigits(2);
  System.out.println(df.format(12.3456789));

  則輸出為:12.35

  3。將數(shù)字轉(zhuǎn)化為百分比輸出,有如下兩種方法:

  (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。設(shè)置分組大小

復制代碼 代碼如下:

  DecimalFormat df1=(DecimalFormat) DecimalFormat.getInstance();
  df1.setGroupingSize(2);
  System.out.println(df1.format(123456789));

  輸出:1,23,45,67,89

  還可以通過df1.setGroupingUsed(false);來禁用分組設(shè)置,如:

復制代碼 代碼如下:

  DecimalFormat df1=(DecimalFormat) DecimalFormat.getInstance();
  df1.setGroupingSize(2);
  df1.setGroupingUsed(false);
  System.out.println(df1.format(123456789));

  輸出:123456789

  5。設(shè)置小數(shù)為必須為2位

復制代碼 代碼如下:

  DecimalFormat df2=(DecimalFormat) DecimalFormat.getInstance();
  df2.applyPattern("0.00");
  System.out.println(df2.format(1.2));

  輸出:1.20

有時我們需要控制輸出的數(shù)字的格式,如何使用java的類庫做到這個呢?
也許你不關(guān)心格式,但是你需要關(guān)心你的程序可以在全世界通用,像下面的這樣一個簡單的語句是依賴地區(qū)的:
    System.out.println(1234.56);
在美國,"." 是小數(shù)點,但在其它地方就不一定了。如何處理這個呢?
java.text 包中的一些包可以處理這類問題。下面的簡單范例使用那些類解決上面提出的問題:

復制代碼 代碼如下:

 import java.text.NumberFormat;
    import java.util.Locale;
    public class DecimalFormat1 {
        public static void main(String args[]) {
            // 得到本地的缺省格式
            NumberFormat nf1 = NumberFormat.getInstance();
            System.out.println(nf1.format(1234.56));
            // 得到德國的格式
            NumberFormat nf2 =
             NumberFormat.getInstance(Locale.GERMAN);
            System.out.println(nf2.format(1234.56));
        }     }
 

   如果你在美國,運行程序后輸出:
    1,234.56
    1.234,56
換句話說,在不同的地方使用不同的習慣表示數(shù)字。
    NumberFormat.getInstance()方法返回NumberFormat的一個實例(實際上是NumberFormat具體的一個子類,例如DecimalFormat), 這適合根據(jù)本地設(shè)置格式化一個數(shù)字。你也可以使用非缺省的地區(qū)設(shè)置,例如德國。然后格式化方法根據(jù)特定的地區(qū)規(guī)則格式化數(shù)字。這個程序也可以使用一個簡單的形式:
    NumberFormat.getInstance().format(1234.56)
但是保存一個格式然后重用更加有效。國際化是格式化數(shù)字時的一個大問題。
另一個是對格式的有效控制,例如指定小數(shù)部分的位數(shù),下面是解決這個問題的一個簡單例子:

復制代碼 代碼如下:

    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));
        }
    }

在這個例子中設(shè)置了數(shù)字的格式,使用像"####.000"的符號。這個模式意味著在小數(shù)點前有四個數(shù)字,如果不夠就空著,小數(shù)點后有三位數(shù)字,不足用0補齊。程序的輸出:
    1234.560
    1234,560
相似的,也可以控制指數(shù)形式的格式,例如:

復制代碼 代碼如下:

    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
對于百分數(shù):

復制代碼 代碼如下:

    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%
至此,你已經(jīng)看到了格式化數(shù)字的幾個不同的技術(shù)。另一方面,如何讀取并解析包含格式化的數(shù)字的字符串?解析支持包含在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"。第一部分使用本地格式解析,第二部分使用德國格式解析。當程序在美國運行,結(jié)果是:
    123456
    1234.56
換句話說,"1234,56"在美國被認為是一個巨大的整數(shù)123456,而在德國被認為是一個小數(shù)"1234.56"。
   還有格式化討論的最后一個問題。在上面的例子中, DecimalFormat 和 NumberFormat 都被使用了。DecimalFormat 常用于獲得很好的格式控制,而NumberFormat 常用于指定不同于本地的地區(qū)。如何結(jié)合兩個類呢?
   答案圍繞著這樣的事實:DecimalFormat是NumberFormat的一個子類,其實例被指定為特定的地區(qū)。因此,你可以使用NumberFormat.getInstance 指定一個地區(qū),然后將結(jié)構(gòu)強制轉(zhuǎn)換為一個DecimalFormat對象。文檔中提到這個技術(shù)可以在大多情況下適用,但是你需要用try/catch 塊包圍強制轉(zhuǎn)換以防轉(zhuǎn)換不能正常工作 (大概在非常不明顯得情況下使用一個奇異的地區(qū))。下面是一個這樣的例子:

復制代碼 代碼如下:

    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 對象并
            // 強制轉(zhuǎn)換為一個 DecimalFormat 對象
            try {
                df = (DecimalFormat)
                    NumberFormat.getInstance(Locale.GERMAN);
            }
            catch (ClassCastException e) {
                System.err.println(e);
            }
            // 設(shè)置格式模式
            df.applyPattern("####.00000");
            // format a number
            System.out.println(df.format(1234.56));
        }
    }

getInstance() 方法獲得格式,然后調(diào)用applyPattern()方法設(shè)置格式模式,輸出:
    1234,56000
如果你不關(guān)心國際化,可以直接使用DecimalFormat 。

相關(guān)文章

  • 解決RedisTemplate存儲至緩存數(shù)據(jù)出現(xiàn)亂碼的情況

    解決RedisTemplate存儲至緩存數(shù)據(jù)出現(xiàn)亂碼的情況

    這篇文章主要介紹了解決RedisTemplate存儲至緩存數(shù)據(jù)出現(xiàn)亂碼的情況,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2021-03-03
  • SpringBoot處理JSON數(shù)據(jù)方法詳解

    SpringBoot處理JSON數(shù)據(jù)方法詳解

    這篇文章主要介紹了SpringBoot整合Web開發(fā)中Json數(shù)據(jù)處理,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2022-10-10
  • mybatis中${}和#{}取值的區(qū)別分析

    mybatis中${}和#{}取值的區(qū)別分析

    mybatis中使用sqlMap進行sql查詢時,經(jīng)常需要動態(tài)傳遞參數(shù),在動態(tài)SQL解析階段, #{ } 和 ${ } 會有不同的表現(xiàn),這篇文章主要給大家介紹了關(guān)于mybatis中${}和#{}取值區(qū)別的相關(guān)資料,需要的朋友可以參考下
    2021-09-09
  • Java字符串拼接+和StringBuilder的比較與選擇

    Java字符串拼接+和StringBuilder的比較與選擇

    Java 提供了兩種主要的方式:使用 "+" 運算符和使用 StringBuilder 類,本文主要介紹了Java字符串拼接+和StringBuilder的比較與選擇,感興趣的可以了解一下
    2023-10-10
  • java 使用foreach遍歷集合元素的實例

    java 使用foreach遍歷集合元素的實例

    這篇文章主要介紹了java 使用foreach遍歷集合元素的實例的相關(guān)資料,這里提供實例幫助大家理解如何使用foreach 進行遍歷,希望能幫助到大家,
    2017-08-08
  • spring boot項目fat jar瘦身的實現(xiàn)

    spring boot項目fat jar瘦身的實現(xiàn)

    這篇文章主要介紹了spring boot項目fat jar瘦身的實現(xiàn),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-06-06
  • java 分行讀取實例

    java 分行讀取實例

    今天小編就為大家分享一篇java 分行讀取實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-07-07
  • Springboot maven plugin插件原理及作用

    Springboot maven plugin插件原理及作用

    這篇文章主要介紹了Springboot maven plugin插件原理及作用,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2020-10-10
  • SpringBoot3中token攔截器鏈的設(shè)計與實現(xiàn)步驟

    SpringBoot3中token攔截器鏈的設(shè)計與實現(xiàn)步驟

    本文介紹了spring boot后端服務(wù)開發(fā)中有關(guān)如何設(shè)計攔截器的思路,文中通過代碼示例和圖文講解的非常詳細,具有一定的參考價值,需要的朋友可以參考下
    2024-03-03
  • java類的全限定名是什么

    java類的全限定名是什么

    Java中的全限定名指的是包含包名和類名的完整標識,例如“java.lang.String”,而非限定名僅指類名,如“String”,全限定名用于區(qū)分不同包中相同名字的類,避免引用混淆,特別是在有多個包含相同類名的庫時
    2024-09-09

最新評論