print(1.1+2.1)
from decimal import Decimal
print(Decimal('1.1')+Decimal('2.1'))
print(Decimal(1.1)+Decimal(2.1))
如图,初学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))
如图,初学python。学习浮点数计算的时候,为什么decimal里面数字加双引号和不加结果不同
这个要说来还是因为二进制。
传字符串进去的时候,Decimal 会存储精确的值。
但是如果传浮点进去,Decimal 会把浮点转成字符串表示,而由于 Decimal 精度较高,所以对浮点进行二进制存储就会出现误差。
比如,你也可以试试这样子:
>>> from decimal import Decimal
>>> Decimal(3.14)
Decimal('3.140000000000000124344978758017532527446746826171875')
>>>