Python中的精确计算 Decimal

  • 浮点数的存储规则不精确,因为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")) # 小数点后两位
发布了127 篇原创文章 · 获赞 25 · 访问量 3万+

猜你喜欢

转载自blog.csdn.net/weixin_44224529/article/details/104052691