`
keke_wanwei
  • 浏览: 126085 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
社区版块
存档分类
最新评论

格式精度控制

阅读更多
//保留小数点后两位小数
public double Number2(double pDouble)
{
  BigDecimal  bd=new  BigDecimal(pDouble);
  BigDecimal  bd1=bd.setScale(2,bd.ROUND_HALF_UP);
  pDouble=bd1.doubleValue();
  long  ll = Double.doubleToLongBits(pDouble);
  return pDouble;
}
格式化输出数字
翻译:Cherami
email:cherami@163.net
原文:http://developer.java.sun.com/developer/TechTips/2000/tt0411.html
* 格式化输出数字
格式化输出数字
有时我们需要控制输出的数字的格式,如何使用java的类库做到这个呢?
也许你不关心格式,但是你需要关心你的程序可以在全世界通用,像下面的这样一个简单的语句是依赖地区的:
    System.out.println(1234.56);
在美国,"." 是小数点,但在其它地方就不一定了。如何处理这个呢?

java.text 包中的一些包可以处理这类问题。下面的简单范例使用那些类解决上面提出的问题:

    import java.text.NumberFormat;

    import java.util.Locale;

    public class DecimalFormat1 {

        public static void main(String args[]) {

            // 得到本地的缺省格式

            NumberFormat nf1 = NumberFormat.getInstance();

            System.out.println(nf1.format(1234.56));

            // 得到德国的格式

            NumberFormat nf2 =

                NumberFormat.getInstance(Locale.GERMAN);

            System.out.println(nf2.format(1234.56));

        }

    }

如果你在美国,运行程序后输出:

    1,234.56

    1.234,56

换句话说,在不同的地方使用不同的习惯表示数字。

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的一个子类,其实例被指定为特定的地区。因此,你可以使用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 。

分享到:
评论

相关推荐

    精度控制mypi.zip

    - `format`命令是MATLAB中用来设置输出格式的,包括精度控制。例如,`format short`会显示结果到4位小数,而`format long`会显示到15位小数。 - 更高级的控制可以使用`format compact`, `format shortG`, `format ...

    RP系统中CAD模型三角网格化的精度控制研究.pdf

    快速成形(RP)技术的发展让CAD模型的实体化更加高效和精确,但在此过程中,模型的三角网格化精度控制成为了一个亟待解决的技术难题。CAD模型在转换为STL(Stereolithography)文件格式时,需要进行三角网格化处理,...

    如何控制MATLAB的输出格式

    vpa 函数则用于解决精度控制的问题,例如: digits(5); a=vpa(sqrt(2)); 这样 a 的值就是 1.4142,而不是准确的 1.4142135623730950488016887242097......。 vpa 函数对每一个运算都控制精度,并非只控制结果。...

    S7-200SMART 双精度浮点型数据转换为单精度浮点型的方法.pdf

    - 程序段3和程序段4中,使用了位移(SHR_DW和SHL_DW)和与(WAND_DW)操作,将需要的位移至适当的位置,以匹配单精度浮点数的格式。 - 程序段5和程序段6中,进一步处理了符号位和指数位,并通过移位和与操作保证了...

    printf格式控制符

    格式控制符的正确使用,可以让输出的结果达到预期的显示效果,例如控制显示宽度、精度和对齐方式等。在本文中,将详细介绍C语言中printf函数的格式控制符。 首先,printf函数的格式控制符包含以下几种转换说明符,...

    对S7-200PLC双精度浮点数转单精度浮点数例程的一点补充

    然而,文章指出,当双精度浮点数的整数部分超过7位时,S7-200 PLC的单精度浮点数格式将无法准确表示。这是由于单精度浮点数的精度限制,最多只能精确到7位有效数字。在这种情况下,作者建议可能需要升级到性能更强的...

    S7-200SMART_双精度浮点数转换为单精度浮点数库文件及使用说明.rar

    同时,符号位、指数部分也需要调整以适应单精度格式。这个过程中可能涉及到舍入和截断策略,以保持数值的合理性。 5. **使用说明**: 使用库文件前,需要将其导入到S7-200SMART的编程环境中,如SIMATIC Step 7 ...

    c++中输入输出流的格式控制符

    为了更好地控制数据的格式化输出,C++提供了多种格式控制符,这些控制符可以帮助程序员精确地设置输出数据的格式,包括数字的进制、对齐方式、精度等。下面将详细介绍这些格式控制符及其用法。 #### 1. 基本格式...

    printf格式控制符的完整格式

    ### printf格式控制符的完整格式 #### 一、概述 `printf` 函数是 C 语言中的一个标准库函数,用于格式化输出数据到标准输出设备(通常是显示器)。`printf` 的格式化输出功能非常强大,它允许用户通过指定特定的...

    c++格式输出控制在使用中容易遗忘!

    ### c++格式输出控制在使用中容易遗忘! 在C++编程语言中,格式化输出是一项非常重要的技能,尤其是在处理复杂的数值或数据展示时。与C语言不同,C++提供了更为高级且灵活的方式来控制输出格式。然而,由于这些功能...

    单精度格式化函数

    这些函数可能具有灵活的参数,能够适应不同的输出需求,比如控制小数位数、四舍五入或者按特定格式输出。 "实例可以自行改用"意味着提供的代码示例是可修改的,用户可以根据自己的项目需求调整代码。这通常是为了...

    工程建设中测量精度控制策略分析.doc

    【工程测量精度控制策略分析】 在当今社会,随着城市化进程的加速和各类建筑项目的增多,工程测量在城市建设、工业及民用建筑中扮演着至关重要的角色。工程测量贯穿于项目的勘测设计、施工建设和管理运营各个阶段,...

    高精度地图OpenDrive格式说明

    OpenDrive格式是一种用于高精度地图的数据规范,它被广泛用于无人驾驶汽车和地图定位研究。OpenDrive格式具有丰富的数据结构,可以精确描述道路的形状、坡度、交通标志和交通信号等信息。它支持多级别精度的地理数据...

    论如何利用大数据控制车身尺寸精度.pdf

    车身尺寸精度控制在汽车制造行业中的重要性 车身尺寸精度是衡量汽车制造水平和产品质量的重要指标。汽车车身作为整车的主要载体,几乎所有零部件都会附着在其上。因此,车身尺寸的精确控制不仅体现了汽车制造企业的...

    单片机系统基于DS3231高精度时钟的北京时间时钟控制器.pdf

    单片机系统基于DS3231高精度时钟的北京时间时钟控制器 本文设计了一种基于高精度时钟的北京时间控制器电路,采用了高精度时钟芯片DS3231,通过按键调整设置成北京时间进行时钟走时,并根据控制策略对4路继电器进行...

    设置Excel 2007数据精度

    为了更好地控制精度,你还可以自定义单元格的数字格式。例如: 1. 选中你需要调整的单元格。 2. 在“开始”选项卡的“数字”组中,点击右侧的箭头,这会打开“设置单元格格式”对话框。 3. 在弹出的对话框中,选择...

    cout输出格式控制

    在C++编程中,对cout这类输出流进行格式控制是一种常见的操作,主要目的是为了使输出结果更加符合预期的格式,比如控制宽度、对齐方式、填充字符、精度等。这种格式控制功能主要依靠操纵运算子来实现,而这些操纵运...

    C++输入输出流格式控制

    ### C++ 输入输出流格式控制 #### 一、使用控制符控制输出格式 在C++中,通过使用一系列预定义的控制符可以方便地控制输出流的格式。这些控制符通常用于`cout`等流对象中,以改变输出数据的表现形式。 - **`dec`*...

Global site tag (gtag.js) - Google Analytics