想七想八不如11408 2023-08-11 12:08 采纳率: 50%
浏览 10
已结题

关于#python#的问题:学习浮点数计算的时候,为什么decimal里面数字加双引号和不加结果不同


print(1.1+2.1)
from decimal import Decimal
print(Decimal('1.1')+Decimal('2.1'))
print(Decimal(1.1)+Decimal(2.1))

img

如图,初学python。学习浮点数计算的时候,为什么decimal里面数字加双引号和不加结果不同

  • 写回答

2条回答 默认 最新

  • P2441M 2023-08-11 12:52
    关注

    这个要说来还是因为二进制。
    传字符串进去的时候,Decimal 会存储精确的值。
    但是如果传浮点进去,Decimal 会把浮点转成字符串表示,而由于 Decimal 精度较高,所以对浮点进行二进制存储就会出现误差。
    比如,你也可以试试这样子:

    >>> from decimal import Decimal
    >>> Decimal(3.14)
    Decimal('3.140000000000000124344978758017532527446746826171875')
    >>>
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 8月19日
  • 已采纳回答 8月11日
  • 创建了问题 8月11日