中国建设银行招聘信息网站6,域名查询seo,北京创意设计协会网站,韩国设计欣赏网站DecimalFormat 是 NumberFormat 的一个具体子类#xff0c;用于格式化十进制数字。它可以支持不同类型的数#xff0c;包括整数 (123)、定点数 (123.4)、科学记数法表示的数 (1.23E4)、百分数 (12%) 和金额 ($123)这些内容的本地化。下边先介绍下DecimalFormat的用法#xf…DecimalFormat 是 NumberFormat 的一个具体子类用于格式化十进制数字。它可以支持不同类型的数包括整数 (123)、定点数 (123.4)、科学记数法表示的数 (1.23E4)、百分数 (12%) 和金额 ($123)这些内容的本地化。下边先介绍下DecimalFormat的用法import java.text.*;import java.util.*;public class DecimalFormatDemo {public static void main(String args[]) {DecimalFormat df1 new DecimalFormat(###,###.0000);//使用系统默认的格式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));//-----------------控制指数输出-------------------------------------------------//DecimalFormat df4 new DecimalFormat();myformat4.applyPattern(0.000E0000);System.out.println(df4.format(10000));System.out.println(df4.format(12345678.345));//------------------百分数的输出-------------------------------------------//DecimalFormat df5 null;try{df5 (DecimalFormat)NumberFormat.getPercentInstance();}catch(ClassCastException e){ System.err.println(e);}df5.applyPattern(00.0000%);System.out.println(df5.format(0.34567));System.out.println(df5.format(1.34567));}}(1)对于数据的四舍五入DecimalFormat 包含一组符号对于各符号的含义解释如下0 一个数字# 一个数字不包括 0. 小数的分隔符的占位符, 分组分隔符的占位符; 分隔格式。- 缺省负数前缀。% 乘以 100 和作为百分比显示? 乘以 1000 和作为千进制货币符显示用货币符号代替如果双写用国际货币符号代替。如果出现在一个模式中用货币十进制分隔符代 替十进制分隔符。X 前缀或后缀中使用的任何其它字符用来引用前缀或后缀中的特殊字符。例如DecimalFormat df1 new DecimalFormat(###0.00) ; //保留两位小数如果不足两位小数则自动补零System.out.println(df1.format(124.367));System.out.println(df1.format(124.3));DecimalFormat df2 new DecimalFormat(###0.##) ; //保留两位小数不足两位则不补零System.out.println(df2.format(124.6));System.out.println(df2.format(124));DecimalFormat df3 new DecimalFormat(000.000); //保留三位小数哪里不足位则补零System.out.println(df3.format(24));DecimalFormat df new DecimalFormat(0.000E0000); //指数System.out.println(df.format(1234.56));DecimalFormat nf (DecimalFormat)NumberFormat.getPercentInstance(); //百分数System.out.println(nf.format(0.476354));nf.applyPattern(00.00%) ;System.out.println(nf.format(0.476354));运行结果124.37124.30124.6124024.0001.235E000348%47.64%(2)对于读取并解析包含格式化的数字的字符串解析支持包含在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);}}运行结果123456 //美国运行被认为字符串1234.56 //德国运行被认为一个小数(3)对于DecimalFormat和NumberFormatDecimalFormat是NumberFormat的一个子类,其实例被指定为特定的地区。因此你可以使用NumberFormat.getInstance 指定一个地区然后将结构强制转换为一个DecimalFormat对象。文档中提到这个技术可以在大多情况下适用但是你需要用try/catch 块包围强制转换以防转换不能正常工作 (大概在非常不明显得情况下使用一个奇异的地区)。以上就是本文的全部内容希望对大家的学习有所帮助也希望大家多多支持脚本之家。