- 浮点数的存储规则不精确,因为0.1 转换为二进制是无限循环的。在内存中规定,多余部分截断。所以在计算浮点型或者精度要求比较的时候,使用Deciaml 模块。 或者转为整型来计算,在把计算结果转回去。
def float_value():
i = 1
while decimal.Decimal(i).quantize(decimal.Decimal("0.00")) != decimal.Decimal(1.5).quantize(decimal.Decimal("0.00")):
i += 0.1
print(i)
float_value()
如果是这样就会死循环:
def float_value():
i =1
while i != 1.5:
i = i+0.1
print(i)
- 设置小数点位数
decimal.Decimal(66.88888).quantize(decimal.Decimal("0.00")) # 小数点后两位