我是一个相当绿色的程序员,我现在正在学习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
发生