您好,登錄后才能下訂單哦!
這篇文章將為大家詳細講解有關JAVA和實現數字千分位和小數點,文章內容質量較高,因此小編分享給大家做個參考,希望大家閱讀完這篇文章后對相關知識有一定的了解。
金融類等項目通常對于金額較大的字段,通常要求千分位顯示,數字保留兩位小數,分裝工具類方便以后工作需要:
說明:
1、井號(#)表示一位數字,逗號是用于分組分隔符的占位符,點是小數點的占位符。
2、如果小數點的右面,值有三位,但是式樣只有兩位。format方法通過四舍五入處理。
3、0 - 如果對應位置上沒有數字,則用零代替
4、# - 如果對應位置上沒有數字,則保持原樣(不用補);如果最前、后為0,則保持為空。
5、正負數模板用分號(;)分割
方法一:
package com.mo.util; import java.text.DecimalFormat; /** * @ClassName: FmtMicrometer * @Description: 格式化數字為千分位工具類 * @author wsq E-mail: * @date 2017-6-1 下午02:25:57 * */ public class FmtMicrometer { /** * @Title: fmtMicrometer * @Description: 格式化數字為千分位 * @param text * @return 設定文件 * @return String 返回類型 */ public static String fmtMicrometer(String text) { DecimalFormat df = null; if (text.indexOf(".") > 0) { if (text.length() - text.indexOf(".") - 1 == 0) { df = new DecimalFormat("###,##0."); } else if (text.length() - text.indexOf(".") - 1 == 1) { df = new DecimalFormat("###,##0.0"); } else { df = new DecimalFormat("###,##0.00"); } } else { df = new DecimalFormat("###,##0"); } double number = 0.0; try { number = Double.parseDouble(text); } catch (Exception e) { number = 0.0; } return df.format(number); } }
在實體類中使用方法:Bean類
package com.mo.test; import com.mo.util.FmtMicrometer; /** * @ClassName: QueryXXDao * @Description: XX查詢Bean類 * @author wsq E-mail: * @date 2017-6-1 下午04:15:10 * */ public class QueryXXDao { //其他字段省略 private String money; public String getMoney() { return FmtMicrometer.fmtMicrometer(money); } public void setMoney(String money) { this.money = FmtMicrometer.fmtMicrometer(money); } @Override public String toString() { return "QueryXXDao [money=" + money + ", getMoney()=" + getMoney() + ", getClass()=" + getClass() + ", hashCode()=" + hashCode() + ", toString()=" + super.toString() + "]"; } }
使用時,直接調用方法就即可
方法二:
不推薦此方法,小數的話存在精度問題,也可自行封裝方法處理,自己在main方法中測試了下
public static void main(String[] args) throws ParseException { NumberFormat numberFormat1 = NumberFormat.getNumberInstance(); System.out.println(numberFormat1.format(11122.33)); //結果是11,122.33 NumberFormat numberFormat2 = NumberFormat.getNumberInstance(); System.out.println(numberFormat2.format(11122.00)); //結果是11,122 NumberFormat numberFormat3 = NumberFormat.getNumberInstance(); numberFormat3.setGroupingUsed(false); //設置了以后不會有千分位,如果不設置,默認是有的 System.out.println(numberFormat3.format(11122.33)); //結果是11122.33 //將一個可能包含千分位的數字轉換為不含千分位的形式: String amount1 = "13,000.00"; double d1 = new DecimalFormat().parse(amount1).doubleValue(); //這里使用的是parse,不是format System.out.println(String.valueOf(d1)); //結果是13000.0 }
補充知識:java BigDecimal用法詳解(保留小數,四舍五入,數字格式化,科學計數法轉數字等)
Java在java.math包中提供的API類BigDecimal,用來對超過16位有效位的數進行精確的運算。雙精度浮點型變量double可以處理16位有效數。在實際應用中,需要對更大或者更小的數進行運算和處理。
float和double只能用來做科學計算或者是工程計算,在商業計算中要用java.math.BigDecimal。
BigDecimal所創建的是對象,我們不能使用傳統的+、-、*、/等算術運算符直接對其對象進行數學運算,而必須調用其相對應的方法。
方法中的參數也必須是BigDecimal的對象。構造器是類的特殊方法,專門用來創建對象,特別是帶有參數的對象。
BigDecimal(int) 創建一個具有參數所指定整數值的對象。
BigDecimal(double) 創建一個具有參數所指定雙精度值的對象。
BigDecimal(long) 創建一個具有參數所指定長整數值的對象。
BigDecimal(String) 創建一個具有參數所指定以字符串表示的數值的對象。
add(BigDecimal) BigDecimal對象中的值相加,然后返回這個對象。
subtract(BigDecimal) BigDecimal對象中的值相減,然后返回這個對象。
multiply(BigDecimal) BigDecimal對象中的值相乘,然后返回這個對象。
divide(BigDecimal) BigDecimal對象中的值相除,然后返回這個對象。
toString() 將BigDecimal對象的數值轉換成字符串。
doubleValue() 將BigDecimal對象中的值以雙精度數返回。
floatValue() 將BigDecimal對象中的值以單精度數返回。
longValue() 將BigDecimal對象中的值以長整數返回。
intValue() 將BigDecimal對象中的值以整數返回。
4.1、保留兩位小數
/** * 保留兩位小數 */ @org.junit.Test public void formatTest() { double num=13.154215; //方式一 DecimalFormat df1 = new DecimalFormat("0.00"); String str = df1.format(num); System.out.println(str); //13.15 //方式二 // #.00 表示兩位小數 #.0000四位小數 DecimalFormat df2 =new DecimalFormat("#.00"); String str2 =df2.format(num); System.out.println(str2); //13.15 //方式三 //%.2f %. 表示 小數點前任意位數 2 表示兩位小數 格式后的結果為f 表示浮點型 String result = String.format("%.2f", num); System.out.println(result); //13.15 }
String.formate用法詳解:
@Test public void test1() { //4.1541483776749997E9 double a = 4887233385.5; double b = 0.85; System.out.println("result1-->"+a*b); // result1-->4.1541483776749997E9 BigDecimal a1 = new BigDecimal(a); BigDecimal b1 = new BigDecimal(b); System.out.println("result2-->"+a1.multiply(b1));//result2-->4154148377.674999891481619無限不循環 BigDecimal aBigDecimal = new BigDecimal(String.valueOf(a)); BigDecimal bBigDecimal = new BigDecimal(String.valueOf(b)); // 或者下面這種寫法 // BigDecimal aBigDecimal = new BigDecimal(Double.toString(a)); // BigDecimal bBigDecimal = new BigDecimal(Double.toString(b)); System.out.println("result3-->"+aBigDecimal.multiply(bBigDecimal)); //result3-->4154148377.675 }
4.2、四舍五入
/** * 四舍五入 */ @Test public void test2() { double num = 111231.5585; BigDecimal b = new BigDecimal(num); //保留2位小數 double result = b.setScale(2, BigDecimal.ROUND_HALF_UP).doubleValue(); System.out.println(result); //111231.56 }
BigDecimal.setScale()方法用于格式化小數點
setScale(1)表示保留一位小數,默認用四舍五入方式
setScale(1,BigDecimal.ROUND_DOWN)直接刪除多余的小數位,如2.35會變成2.3
setScale(1,BigDecimal.ROUND_UP)進位處理,2.35變成2.4
setScale(1,BigDecimal.ROUND_HALF_UP)四舍五入,2.35變成2.4
setScaler(1,BigDecimal.ROUND_HALF_DOWN)四舍五入,2.35變成2.3,如果是5則向下舍
setScaler(1,BigDecimal.ROUND_CEILING)接近正無窮大的舍入
setScaler(1,BigDecimal.ROUND_FLOOR)接近負無窮大的舍入,數字>0和ROUND_UP作用一樣,數字<0和ROUND_DOWN作用一樣
setScaler(1,BigDecimal.ROUND_HALF_EVEN)向最接近的數字舍入,如果與兩個相鄰數字的距離相等,則向相鄰的偶數舍入。
注釋:
1:scale指的是你小數點后的位數。比如123.456則score就是3.
score()就是BigDecimal類中的方法啊。
比如:BigDecimal b = new BigDecimal("123.456");
b.scale(),返回的就是3.
2:roundingMode是小數的保留模式。它們都是BigDecimal中的常量字段,有很多種。
比如:BigDecimal.ROUND_HALF_UP表示的就是4舍5入。
3:pubilc BigDecimal divide(BigDecimal divisor, int scale, int roundingMode)
的意思是說:我用一個BigDecimal對象除以divisor后的結果,并且要求這個結果保留有scale個小數位,roundingMode表示的就是保留模式是什么,是四舍五入啊還是其它的,你可以自己選!
4:對于一般add、subtract、multiply方法的小數位格式化如下:
BigDecimal mData = new BigDecimal("9.655").setScale(2, BigDecimal.ROUND_HALF_UP); System.out.println("mData=" + mData); ----結果:----- mData=9.66
4.3、格式化
由于NumberFormat類的format()方法可以使用BigDecimal對象作為其參數,可以利用BigDecimal對超出16位有效數字的貨幣值,百分值,以及一般數值進行格式化控制。
/** * 格式化 */ @Test public void test3() { NumberFormat currency = NumberFormat.getCurrencyInstance(); //建立貨幣格式化引用 NumberFormat percent = NumberFormat.getPercentInstance(); //建立百分比格式化引用 percent.setMaximumFractionDigits(3); //百分比小數點最多3位 BigDecimal loanAmount = new BigDecimal("150.48"); //貸款金額 BigDecimal interestRate = new BigDecimal("0.008"); //利率 BigDecimal interest = loanAmount.multiply(interestRate); //相乘 System.out.println("貸款金額:\t" + currency.format(loanAmount)); //貸款金額: ¥150.48 System.out.println("利率:\t" + percent.format(interestRate)); //利率: 0.8% System.out.println("利息:\t" + currency.format(interest)); //利息: ¥1.20 }
@Test public void test3() { DecimalFormat df = new DecimalFormat(); double data = 1234.56789; //格式化之前的數字 //1、定義要顯示的數字的格式(這種方式會四舍五入) String style = "0.0"; df.applyPattern(style); System.out.println("1-->" + df.format(data)); //1234.6 //2、在格式后添加諸如單位等字符 style = "00000.000 kg"; df.applyPattern(style); System.out.println("2-->" + df.format(data)); //01234.568 kg //3、 模式中的"#"表示如果該位存在字符,則顯示字符,如果不存在,則不顯示。 style = "##000.000 kg"; df.applyPattern(style); System.out.println("3-->" + df.format(data)); //1234.568 kg //4、 模式中的"-"表示輸出為負數,要放在最前面 style = "-000.000"; df.applyPattern(style); System.out.println("4-->" + df.format(data)); //-1234.568 //5、 模式中的","在數字中添加逗號,方便讀數字 style = "-0,000.0#"; df.applyPattern(style); System.out.println("5-->" + df.format(data)); //5-->-1,234.57 //6、模式中的"E"表示輸出為指數,"E"之前的字符串是底數的格式, // "E"之后的是字符串是指數的格式 style = "0.00E000"; df.applyPattern(style); System.out.println("6-->" + df.format(data)); //6-->1.23E003 //7、 模式中的"%"表示乘以100并顯示為百分數,要放在最后。 style = "0.00%"; df.applyPattern(style); System.out.println("7-->" + df.format(data)); //7-->123456.79% //8、 模式中的"\u2030"表示乘以1000并顯示為千分數,要放在最后。 style = "0.00\u2030"; //在構造函數中設置數字格式 DecimalFormat df1 = new DecimalFormat(style); //df.applyPattern(style); System.out.println("8-->" + df1.format(data)); //8-->1234567.89‰ }
4.4、BigDecimal比較
BigDecimal是通過使用compareTo(BigDecimal)來比較的,具體比較情況如下:
/** * 注意不能使用equals方法來比較大小。 * * 使用BigDecimal的壞處是性能比double和float差,在處理龐大,復雜的運算時尤為明顯,因根據實際需求決定使用哪種類型。 */ @Test public void test4() { BigDecimal a = new BigDecimal("1"); BigDecimal b = new BigDecimal("2"); BigDecimal c = new BigDecimal("1"); int result1 = a.compareTo(b); int result2 = a.compareTo(c); int result3 = b.compareTo(a); System.out.println(result1); //-1 System.out.println(result2); //0 System.out.println(result3); //1 }
4.5、科學計數法
有些項目可能會涉及到從Excel導入數據,但如果Excel里單元格類型為數值,但內容數據太長時(如銀行賬號),導入時,會默認讀取為科學計數法,用以下代碼便輕松解決。
@Test public void test5() { BigDecimal bd = new BigDecimal("3.40256010353E11"); String result = bd.toPlainString(); System.out.println(result); //340256010353 }
4.6、java中價格的數字中間有逗號的處理
@Test public void test1() { java.util.StringTokenizer st = new StringTokenizer( "123,456,789", ","); StringBuffer sb = new StringBuffer(); while(st.hasMoreTokens()) { sb.append(st.nextToken()); } System.out.println(sb); //123456789 } @Test public void test2() { String str = "123,456,789"; str = str.replace(",", ""); System.out.println(str); //123456789 }
4.7.精確計算
double value1=1.00; String value2 = "1.00"; BigDecimal b1 = new BigDecimal(Double.valueOf(value1)); BigDecimal b1 = new BigDecimal(String.valueOf(value2)); public BigDecimal add(BigDecimal value); //加法 public BigDecimal subtract(BigDecimal value); //減法 public BigDecimal multiply(BigDecimal value); //乘法 public BigDecimal divide(BigDecimal value); //除法
下面是一個工具類,該工具類提供加,減,乘,除運算。
public class Arith { /** * 提供精確加法計算的add方法 * @param value1 被加數 * @param value2 加數 * @return 兩個參數的和 */ public static double add(double value1,double value2){ BigDecimal b1 = new BigDecimal(Double.valueOf(value1)); BigDecimal b2 = new BigDecimal(Double.valueOf(value2)); return b1.add(b2).doubleValue(); } /** * 提供精確減法運算的sub方法 * @param value1 被減數 * @param value2 減數 * @return 兩個參數的差 */ public static double sub(double value1,double value2){ BigDecimal b1 = new BigDecimal(Double.valueOf(value1)); BigDecimal b2 = new BigDecimal(Double.valueOf(value2)); return b1.subtract(b2).doubleValue(); } /** * 提供精確乘法運算的mul方法 * @param value1 被乘數 * @param value2 乘數 * @return 兩個參數的積 */ public static double mul(double value1,double value2){ BigDecimal b1 = new BigDecimal(Double.valueOf(value1)); BigDecimal b2 = new BigDecimal(Double.valueOf(value2)); return b1.multiply(b2).doubleValue(); } /** * 提供精確的除法運算方法div * @param value1 被除數 * @param value2 除數 * @param scale 精確范圍 * @return 兩個參數的商 * @throws IllegalAccessException */ public static double div(double value1,double value2,int scale) throws IllegalAccessException{ //如果精確范圍小于0,拋出異常信息 if(scale<0){ throw new IllegalAccessException("精確度不能小于0"); } BigDecimal b1 = new BigDecimal(Double.valueOf(value1)); BigDecimal b2 = new BigDecimal(Double.valueOf(value2)); return b1.divide(b2, scale).doubleValue(); } }
關于JAVA和實現數字千分位和小數點就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。