Python中数字值的陷阱,“有多深?”

我是一个相当绿色的程序员,我现在正在学习Python.我在“学会像计算机科学家一样思考”(课程和方法)的第17章,我刚刚写了我的第一个doctest,它以一种我真正不完全理解的方式失败了:

class Point(object):
    '''
    represents a point object.
    attributes: x, y
    '''

    def ___init___(self, x = 0, y = 0):
        '''
        >>> point = Point()
        >>> point.y
        0
        >>> point = Point(4.7, 8.2)
        >>> point.x
        4.7
        '''

        self.x = x
        self.y = y

__init__的第二个doctest失败,返回4.7000000000000002而不是4.7.但是,如果我用“print”语句重写doctest如下:

>>> point = Point(4.7, 8.2)
>>> print point.x
4.7

它运行正常.

所以我读了Python如何存储浮点数,现在我明白,由于十进制数字的二进制表示,差异的原因是Python将4.7存储为1和0的字符串,几乎但不完全相等4.7 .

但我不明白为什么调用“point.x”返回4.7000000000000002并调用“print point.x”返回4.7.在其他情况下,Python会选择像“打印”一样进行舍入?这种四舍五入如何运作?这些尾随有意义的数字是否会导致编程错误(除了显然,失败的doctests)?未能注意四舍五入会造成危险的歧义吗?

由于这与十进制数的二进制表示有关,我确信这实际上是一个普通的CS问题,而不是Python特有的问题,但我现在真正需要知道的是我能做什么,特别是作为一个Python程序员,以避免任何相关问题和/或bug感染.

另外,对于奖励积分,除了由“a = 4.7”这样的行激活的默认值之外,还有其他一些方法可以存储浮点数吗?我知道有Decimal包,但我不完全确定它是如何工作的.老实说,所有这些动态打字的东西有时会让我感到困惑.

编辑:
我应该指定我使用的是Python 2.6(在某些时候我想使用NumPy和Biopython)

解决方法:

>>> point.x

调用repr函数,该函数用于字符串表示,其中包含比strfunction更多的技术信息

>>> print point.x

发生

上一篇:C函数重载类似转换


下一篇:c – 浮点和整数模糊度