DecimalFormat多种用法详解
numberformat.getinstance()方法返回numberformat的一个实例(实际上是numberformat具体的一个子类,例如decimalformat), 这适合根据本地设置格式化一个数字。你也可以使用非缺省的地区设置,例如德国。然后格式化方法根据特定的地区规则格式化数字。这个程序也可以使用一个简单的形式:
numberformat.getinstance().format(1234.56)
但是保存一个格式然后重用更加有效。国际化是格式化数字时的一个大问题。
另一个是对格式的有效控制,例如指定小数部分的位数,下面是解决这个问题的一个简单例子:
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)); } }
在这个例子中设置了数字的格式,使用像"####.000"的符号。这个模式意味着在小数点前有四个数字,如果不够就空着,小数点后有三位数字,不足用0补齐。程序的输出:
1234.560
1234,560
相似的,也可以控制指数形式的格式,例如:
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
对于百分数:
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%
至此,你已经看到了格式化数字的几个不同的技术。另一方面,如何读取并解析包含格式化的数字的字符串?解析支持包含在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"。第一部分使用本地格式解析,第二部分使用德国格式解析。当程序在美国运行,结果是:
123456
1234.56
换句话说,"1234,56"在美国被认为是一个巨大的整数"123456"而在德国被认为是一个小数"1234.56"。
decimalformat 和numberformat的联系
在上面的例子中, decimalformat 和 numberformat 都被使用了。decimalformat 常用于获得很好的格式控制,而numberformat 常用于指定不同于本地的地区。如何结合两个类呢?
答案围绕着这样的事实:decimalformat是numberformat的一个子类,其实例被指定为特定的地区。因此,你可以使用numberformat.getinstance 指定一个地区,然后将结构强制转换为一个decimalformat对象。文档中提到这个技术可以在大多情况下适用,但是你需要用try/catch 块包围强制转换以防转换不能正常工作 (大概在非常不明显得情况下使用一个奇异的地区)。下面是一个这样的例子:
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 对象并 // 强制转换为一个 decimalformat 对象 try { df = (decimalformat)numberformat.getinstance(locale.german); } catch (classcastexception e) { system.err.println(e); } // 设置格式模式 df.applypattern("####.00000"); // format a number system.out.println(df.format(1234.56)); } }
getinstance() 方法获得格式,然后调用applypattern()方法设置格式模式,输出:
1234,56000
如果你不关心国际化,可以直接使用decimalformat 。
其中v 为未处理的double,scale为需求精度,返回需要小数位数的double
public static double round(double v,int scale){ if(scale<0){ throw new illegalargumentexception( "the scale must be a positive integer or zero"); } bigdecimal b = new bigdecimal(double.tostring(v)); bigdecimal one = new bigdecimal("1"); return b.divide(one,scale,bigdecimal.round_half_up).doublevalue(); }
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
推荐阅读
-
详解Linux中的cat文本输出命令用法
-
ThinkPHP模板循环输出Volist标签用法实例详解,thinkphpvolist_PHP教程
-
详解PHP中cookie和session的区别及cookie和session用法小结,cookiesession
-
php:switch case 和 if else 的用法区别及运行效率详解
-
PHP中try{}catch{}的具体用法详解
-
PHP预定义变量9大超全局数组用法详解,全局数组
-
PHP邮件发送类PHPMailer用法实例详解_PHP
-
SQL中Exists的用法实例详解
-
javascript基础课程之算数表达式定义用法详解
-
css3图片边框border-image的用法实例详解