java.text.MessageFormat格式化数字

2018-12-29  本文已影响0人  晚歌歌

昨天遇到MessageFormat格式化数字有坑,就是超过三位数的数字,格式化之后会自动变成国外数字的记法(百位之后每三位数字用逗号分隔),比如9999会变为9,999之类的。

由于这个原因,导致我给银行出修数SQL的时候没有检查出SQL中数字格式化存在的问题,SQL中的数字是不能使用逗号的,否则会被当成语句内逗号分隔符,类似下面这条语句会报错。

update report_repay_detail set bank_interest_income=915,bank_overdue_income=0,bank_overdue_vat=0,bank_payable_vat=55,interest_income=1,217,overdue_amount=0,overdue_income=0,overdue_vat=0,payable_vat=73,qudian_interest_income=302,qudian_overdue_income=0,qudian_overdue_vat=0,qudian_payable_vat=18,bill_interest=1,290,capital_overdue_days=0,interest_overdue_days=0,reserve_amount=205,reserve_amount_income=193,reserve_amount_vat=12 where bill_no ='10180914126455133';

这边就不看源码了,跑点测试案例记录一下哪些情况会出现我们预期之外的结果。

public static void main(String[] args) {
        System.out.println(MessageFormat.format("{0}   {1}", 999,9999));
        System.out.println(MessageFormat.format("{0}   {1}", new Integer(999).toString(),new Integer(9999).toString()));
        System.out.println(MessageFormat.format("{0}   {1}   {2}", 9999.999,99999.9999,99999.4444444));
    }

//输出
999   9,999
999   9999
9,999.999   100,000   99,999.444

通过以上案例可以看出
1、数字超过三位数的,会自动添加逗号分隔符
2、数字后面小数最多保留三位,超过三位小数的会自动进行四舍五入
3、如果不需要默认的这种格式化模式,只需要把数字全部转成字符串即可。

这边就只测试了一下数字格式化方面会出现的问题,日期格式化同样会有一些问题,但只要替换参数使用字符串绝对没有问题。

总结:使用MessageFormat格式化数字、日期的时候,传入的替换参数最好先转成我们所需要格式的字符串类型变量,否则容易被MessageFormat格式化成我们预期之外的结果。

上一篇下一篇

猜你喜欢

热点阅读