1 >>> 0.1 + 0.1 +0.1 == 0.3 2 False 3 >>> 4 >>> print(0.1 + 0.1 + 0.1) 5 0.30000000000000004
what???
0.1 + 0.1 +0.1 == 0.3 判断为假
0.1 + 0.1 + 0.1 == 0.30000000000000004
from decimal import Decimal
>>> from decimal import Decimal
>>> Decimal(‘7.1‘) / Decimal(‘3.1‘)
Decimal(‘2.290322580645161290322580645‘)
这个demo中有3个知识点:
(1)Decimal()的参数是字符串,如果不注意这一点,把浮点数作为参数传递进来,得到的结果还是不精确的
>>> Decimal(0.1) + Decimal(0.1) + Decimal(0.1)
Decimal(‘0.3000000000000000166533453694‘)
>>>
>>> Decimal(1.2) + Decimal(1.8)
Decimal(‘3.000000000000000000000000000‘)
>>> Decimal(‘1.2‘) + Decimal(‘1.8‘)
Decimal(‘3.0‘)
>>>
(2)计算结果返回的还是Decimal类型 ,可以用float()函数将其转换为浮点数
>>> a = Decimal(‘7.1‘) / Decimal(‘3.1‘)
>>> float(a)
2.2903225806451615
Decimal类型能通过int()转换为整型吗?
>>> b = Decimal(‘1.0‘) + Decimal(‘1.0‘)
>>> int(b)
2
>>>
>>> c = Decimal(‘1.0‘) + Decimal(‘1.1‘)
>>> int(c)
2 #哦,这样啊,转换成整数的时候是只取整数部分的,不试一下还真不知道
(3)浮点型计算中经常会遇到的一个问题,两数相除,但不能相除的情况
>>> Decimal(‘2‘) / Decimal(‘3‘)
Decimal(‘0.6666666666666666666666666667‘) #小数点后面这么多位啊,可是要那么多位没什么用啊,肿么办?
可以事先自定义一下Decimal计算的精度
>>> Decimal(‘1.0‘) / Decimal(‘3.0‘)
Decimal(‘0.3333333333333333333333333333‘)
>>>
>>> from decimal import getcontext
>>> getcontext().prec = 4
>>> Decimal(‘1.0‘) / Decimal(‘3.0‘)
Decimal(‘0.3333‘)
>>>