JAVA数字千分位和小数点的现实代码(处理金额问题)
金融类等项目通常对于金额较大的字段,通常要求千分位显示,数字保留两位小数,分装工具类方便以后工作需要:
说明:
1、井号(#)表示一位数字,逗号是用于分组分隔符的占位符,点是小数点的占位符。
2、如果小数点的右面,值有三位,但是式样只有两位。format方法通过四舍五入处理。
3、0-如果对应位置上没有数字,则用零代替
4、#-如果对应位置上没有数字,则保持原样(不用补);如果最前、后为0,则保持为空。
5、正负数模板用分号(;)分割
方法一:
packagecom.mo.util;
importjava.text.DecimalFormat;
/**
*@ClassName:FmtMicrometer
*@Description:格式化数字为千分位工具类
*@authorwsqE-mail:
*@date2017-6-1下午02:25:57
*
*/
publicclassFmtMicrometer{
/**
*@Title:fmtMicrometer
*@Description:格式化数字为千分位
*@paramtext
*@return设定文件
*@returnString返回类型
*/
publicstaticStringfmtMicrometer(Stringtext){
DecimalFormatdf=null;
if(text.indexOf(".")>0){
if(text.length()-text.indexOf(".")-1==0){
df=newDecimalFormat("###,##0.");
}elseif(text.length()-text.indexOf(".")-1==1){
df=newDecimalFormat("###,##0.0");
}else{
df=newDecimalFormat("###,##0.00");
}
}else{
df=newDecimalFormat("###,##0");
}
doublenumber=0.0;
try{
number=Double.parseDouble(text);
}catch(Exceptione){
number=0.0;
}
returndf.format(number);
}
}
在实体类中使用方法:Bean类
packagecom.mo.test;
importcom.mo.util.FmtMicrometer;
/**
*@ClassName:QueryXXDao
*@Description:XX查询Bean类
*@authorwsqE-mail:
*@date2017-6-1下午04:15:10
*
*/
publicclassQueryXXDao{
//其他字段省略
privateStringmoney;
publicStringgetMoney(){
returnFmtMicrometer.fmtMicrometer(money);
}
publicvoidsetMoney(Stringmoney){
this.money=FmtMicrometer.fmtMicrometer(money);
}
@Override
publicStringtoString(){
return"QueryXXDao[money="+money+",getMoney()="+getMoney()
+",getClass()="+getClass()+",hashCode()="+hashCode()
+",toString()="+super.toString()+"]";
}
}
使用时,直接调用方法就即可
方法二:
不推荐此方法,小数的话存在精度问题,也可自行封装方法处理,自己在main方法中测试了下
publicstaticvoidmain(String[]args)throwsParseException{
NumberFormatnumberFormat1=NumberFormat.getNumberInstance();
System.out.println(numberFormat1.format(11122.33));//结果是11,122.33
NumberFormatnumberFormat2=NumberFormat.getNumberInstance();
System.out.println(numberFormat2.format(11122.00));//结果是11,122
NumberFormatnumberFormat3=NumberFormat.getNumberInstance();
numberFormat3.setGroupingUsed(false);//设置了以后不会有千分位,如果不设置,默认是有的
System.out.println(numberFormat3.format(11122.33));//结果是11122.33
//将一个可能包含千分位的数字转换为不含千分位的形式:
Stringamount1="13,000.00";
doubled1=newDecimalFormat().parse(amount1).doubleValue();//这里使用的是parse,不是format
System.out.println(String.valueOf(d1));//结果是13000.0
}
补充知识:javaBigDecimal用法详解(保留小数,四舍五入,数字格式化,科学计数法转数字等)
一、简介
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
publicvoidformatTest(){
doublenum=13.154215;
//方式一
DecimalFormatdf1=newDecimalFormat("0.00");
Stringstr=df1.format(num);
System.out.println(str);//13.15
//方式二
//#.00表示两位小数#.0000四位小数
DecimalFormatdf2=newDecimalFormat("#.00");
Stringstr2=df2.format(num);
System.out.println(str2);//13.15
//方式三
//%.2f%.表示小数点前任意位数2表示两位小数格式后的结果为f表示浮点型
Stringresult=String.format("%.2f",num);
System.out.println(result);//13.15
}
String.formate用法详解:
@Test
publicvoidtest1(){//4.1541483776749997E9
doublea=4887233385.5;
doubleb=0.85;
System.out.println("result1-->"+a*b);//result1-->4.1541483776749997E9
BigDecimala1=newBigDecimal(a);
BigDecimalb1=newBigDecimal(b);
System.out.println("result2-->"+a1.multiply(b1));//result2-->4154148377.674999891481619无限不循环
BigDecimalaBigDecimal=newBigDecimal(String.valueOf(a));
BigDecimalbBigDecimal=newBigDecimal(String.valueOf(b));
//或者下面这种写法
//BigDecimalaBigDecimal=newBigDecimal(Double.toString(a));
//BigDecimalbBigDecimal=newBigDecimal(Double.toString(b));
System.out.println("result3-->"+aBigDecimal.multiply(bBigDecimal));//result3-->4154148377.675
}
4.2、四舍五入
/**
*四舍五入
*/
@Test
publicvoidtest2(){
doublenum=111231.5585;
BigDecimalb=newBigDecimal(num);
//保留2位小数
doubleresult=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类中的方法啊。
比如:BigDecimalb=newBigDecimal("123.456");
b.scale(),返回的就是3.
2:roundingMode是小数的保留模式。它们都是BigDecimal中的常量字段,有很多种。
比如:BigDecimal.ROUND_HALF_UP表示的就是4舍5入。
3:pubilcBigDecimaldivide(BigDecimaldivisor,intscale,introundingMode)
的意思是说:我用一个BigDecimal对象除以divisor后的结果,并且要求这个结果保留有scale个小数位,roundingMode表示的就是保留模式是什么,是四舍五入啊还是其它的,你可以自己选!
4:对于一般add、subtract、multiply方法的小数位格式化如下:
BigDecimalmData=newBigDecimal("9.655").setScale(2,BigDecimal.ROUND_HALF_UP);
System.out.println("mData="+mData);
----结果:-----mData=9.66
4.3、格式化
由于NumberFormat类的format()方法可以使用BigDecimal对象作为其参数,可以利用BigDecimal对超出16位有效数字的货币值,百分值,以及一般数值进行格式化控制。
/**
*格式化
*/
@Test
publicvoidtest3(){
NumberFormatcurrency=NumberFormat.getCurrencyInstance();//建立货币格式化引用
NumberFormatpercent=NumberFormat.getPercentInstance();//建立百分比格式化引用
percent.setMaximumFractionDigits(3);//百分比小数点最多3位
BigDecimalloanAmount=newBigDecimal("150.48");//贷款金额
BigDecimalinterestRate=newBigDecimal("0.008");//利率
BigDecimalinterest=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
publicvoidtest3(){
DecimalFormatdf=newDecimalFormat();
doubledata=1234.56789;//格式化之前的数字
//1、定义要显示的数字的格式(这种方式会四舍五入)
Stringstyle="0.0";
df.applyPattern(style);
System.out.println("1-->"+df.format(data));//1234.6
//2、在格式后添加诸如单位等字符
style="00000.000kg";
df.applyPattern(style);
System.out.println("2-->"+df.format(data));//01234.568kg
//3、模式中的"#"表示如果该位存在字符,则显示字符,如果不存在,则不显示。
style="##000.000kg";
df.applyPattern(style);
System.out.println("3-->"+df.format(data));//1234.568kg
//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";
//在构造函数中设置数字格式
DecimalFormatdf1=newDecimalFormat(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
publicvoidtest4(){
BigDecimala=newBigDecimal("1");
BigDecimalb=newBigDecimal("2");
BigDecimalc=newBigDecimal("1");
intresult1=a.compareTo(b);
intresult2=a.compareTo(c);
intresult3=b.compareTo(a);
System.out.println(result1);//-1
System.out.println(result2);//0
System.out.println(result3);//1
}
4.5、科学计数法
有些项目可能会涉及到从Excel导入数据,但如果Excel里单元格类型为数值,但内容数据太长时(如银行账号),导入时,会默认读取为科学计数法,用以下代码便轻松解决。
@Test
publicvoidtest5(){
BigDecimalbd=newBigDecimal("3.40256010353E11");
Stringresult=bd.toPlainString();
System.out.println(result);//340256010353
}
4.6、java中价格的数字中间有逗号的处理
@Test
publicvoidtest1(){
java.util.StringTokenizerst=newStringTokenizer("123,456,789",",");
StringBuffersb=newStringBuffer();
while(st.hasMoreTokens()){
sb.append(st.nextToken());
}
System.out.println(sb);//123456789
}
@Test
publicvoidtest2(){
Stringstr="123,456,789";
str=str.replace(",","");
System.out.println(str);//123456789
}
4.7.精确计算
doublevalue1=1.00; Stringvalue2="1.00"; BigDecimalb1=newBigDecimal(Double.valueOf(value1)); BigDecimalb1=newBigDecimal(String.valueOf(value2)); publicBigDecimaladd(BigDecimalvalue);//加法 publicBigDecimalsubtract(BigDecimalvalue);//减法 publicBigDecimalmultiply(BigDecimalvalue);//乘法 publicBigDecimaldivide(BigDecimalvalue);//除法
下面是一个工具类,该工具类提供加,减,乘,除运算。
publicclassArith{
/**
*提供精确加法计算的add方法
*@paramvalue1被加数
*@paramvalue2加数
*@return两个参数的和
*/
publicstaticdoubleadd(doublevalue1,doublevalue2){
BigDecimalb1=newBigDecimal(Double.valueOf(value1));
BigDecimalb2=newBigDecimal(Double.valueOf(value2));
returnb1.add(b2).doubleValue();
}
/**
*提供精确减法运算的sub方法
*@paramvalue1被减数
*@paramvalue2减数
*@return两个参数的差
*/
publicstaticdoublesub(doublevalue1,doublevalue2){
BigDecimalb1=newBigDecimal(Double.valueOf(value1));
BigDecimalb2=newBigDecimal(Double.valueOf(value2));
returnb1.subtract(b2).doubleValue();
}
/**
*提供精确乘法运算的mul方法
*@paramvalue1被乘数
*@paramvalue2乘数
*@return两个参数的积
*/
publicstaticdoublemul(doublevalue1,doublevalue2){
BigDecimalb1=newBigDecimal(Double.valueOf(value1));
BigDecimalb2=newBigDecimal(Double.valueOf(value2));
returnb1.multiply(b2).doubleValue();
}
/**
*提供精确的除法运算方法div
*@paramvalue1被除数
*@paramvalue2除数
*@paramscale精确范围
*@return两个参数的商
*@throwsIllegalAccessException
*/
publicstaticdoublediv(doublevalue1,doublevalue2,intscale)throwsIllegalAccessException{
//如果精确范围小于0,抛出异常信息
if(scale<0){
thrownewIllegalAccessException("精确度不能小于0");
}
BigDecimalb1=newBigDecimal(Double.valueOf(value1));
BigDecimalb2=newBigDecimal(Double.valueOf(value2));
returnb1.divide(b2,scale).doubleValue();
}
}
以上这篇JAVA数字千分位和小数点的现实代码(处理金额问题)就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持毛票票。