java中DecimalFormat四舍五入用法詳解
DecimalFormat 是 NumberFormat 的一個(gè)具體子類,用于格式化十進(jìn)制數(shù)字。它可以支持不同類型的數(shù),包括整數(shù) (123)、定點(diǎn)數(shù) (123.4)、科學(xué)記數(shù)法表示的數(shù) (1.23E4)、百分?jǐn)?shù) (12%) 和金額 ($123)這些內(nèi)容的本地化。
下邊先介紹下DecimalFormat的用法:
import java.text.*;
import java.util.*;
public class DecimalFormatDemo {
public static void main(String args[]) {
DecimalFormat df1 = new DecimalFormat("###,###.0000");//使用系統(tǒng)默認(rèn)的格式
System.out.println(df1.format(111111123456.12));
Locale.setDefault(Locale.US);
DecimalFormat df2= new DecimalFormat("###,###.0000");//使用美國的格式
System.out.println(df2.format(111111123456.12));
//----------------------------also use applypattern------------------------------//
DecimalFormat df3= new DecimalFormat();
myformat3.applyPattern("##,###.000");
System.out.println(df3.format(11112345.12345));
//-----------------控制指數(shù)輸出-------------------------------------------------//
DecimalFormat df4= new DecimalFormat();
myformat4.applyPattern("0.000E0000");
System.out.println(df4.format(10000));
System.out.println(df4.format(12345678.345));
//------------------百分?jǐn)?shù)的輸出-------------------------------------------//
DecimalFormat df5= null;
try{
df5= (DecimalFormat)NumberFormat.getPercentInstance();
}catch(ClassCastException e){
<span style="white-space:pre"> </span> System.err.println(e);
}
df5.applyPattern("00.0000%");
System.out.println(df5.format(0.34567));
System.out.println(df5.format(1.34567));
}
}
(1)對于數(shù)據(jù)的四舍五入:
DecimalFormat 包含一組符號,對于各符號的含義解釋如下:
0 一個(gè)數(shù)字
# 一個(gè)數(shù)字,不包括 0
. 小數(shù)的分隔符的占位符
, 分組分隔符的占位符
; 分隔格式。
- 缺省負(fù)數(shù)前綴。
% 乘以 100 和作為百分比顯示
? 乘以 1000 和作為千進(jìn)制貨幣符顯示;用貨幣符號代替;如果雙寫,用國際貨幣符號代替。如果出現(xiàn)在一個(gè)模式中,用貨幣十進(jìn)制分隔符代 替十進(jìn)制分隔符。
X 前綴或后綴中使用的任何其它字符,用來引用前綴或后綴中的特殊字符。
例如:
DecimalFormat df1 = new DecimalFormat("###0.00") ; //保留兩位小數(shù),如果不足兩位小數(shù)則自動補(bǔ)零
System.out.println(df1.format(124.367));
System.out.println(df1.format(124.3));
DecimalFormat df2 = new DecimalFormat("###0.##") ; //保留兩位小數(shù),不足兩位則不補(bǔ)零
System.out.println(df2.format(124.6));
System.out.println(df2.format(124));
DecimalFormat df3 = new DecimalFormat("000.000"); //保留三位小數(shù),哪里不足位則補(bǔ)零
System.out.println(df3.format(24));
DecimalFormat df = new DecimalFormat("0.000E0000"); //指數(shù)
System.out.println(df.format(1234.56));
DecimalFormat nf = (DecimalFormat)NumberFormat.getPercentInstance(); //百分?jǐn)?shù)
System.out.println(nf.format(0.476354));
nf.applyPattern("00.00%") ;
System.out.println(nf.format(0.476354));
運(yùn)行結(jié)果:
124.37 124.30 124.6 124 024.000 1.235E0003 48% 47.64%
(2)對于讀取并解析包含格式化的數(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);
}
}
運(yùn)行結(jié)果:
123456 //美國運(yùn)行;被認(rèn)為字符串 1234.56 //德國運(yùn)行;被認(rèn)為一個(gè)小數(shù)
(3)對于DecimalFormat和NumberFormat:
DecimalFormat是NumberFormat的一個(gè)子類,其實(shí)例被指定為特定的地區(qū)。因此,你可以使用NumberFormat.getInstance 指定一個(gè)地區(qū),然后將結(jié)構(gòu)強(qiáng)制轉(zhuǎn)換為一個(gè)DecimalFormat對象。文檔中提到這個(gè)技術(shù)可以在大多情況下適用,但是你需要用try/catch 塊包圍強(qiáng)制轉(zhuǎn)換以防轉(zhuǎn)換不能正常工作 (大概在非常不明顯得情況下使用一個(gè)奇異的地區(qū))。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Java Swing SpringLayout彈性布局的實(shí)現(xiàn)代碼
這篇文章主要介紹了Java Swing SpringLayout彈性布局的實(shí)現(xiàn)代碼,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-12-12
java實(shí)現(xiàn)簡單的圖書借閱系統(tǒng)
這篇文章主要為大家詳細(xì)介紹了java實(shí)現(xiàn)簡單的圖書借閱系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-03-03
java中java.util.Date和java.sql.Date之間的轉(zhuǎn)換的示例
java.util.Date是java.sql.Date的父類,有時(shí)候在和SqlServer數(shù)據(jù)庫打交道時(shí),也會遇到,本文主要介紹了java中java.util.Date和java.sql.Date之間的轉(zhuǎn)換的示例,具有一定的參考價(jià)值,感興趣的可以了解一下2024-05-05

