decimal 模块为正确舍入十进制浮点运算提供了支持,相比内置的浮点类型 float,它能更加精确的控制精度,能够为精度要求较高的金融等领域提供支持。
decimal 在一个独立的 context 下工作,可以使用 getcontext() 查看当前上下文,如下所示:
>> from decimal import * >>> getcontext() Context(prec=28, rounding=ROUND_HALF_EVEN, Emin=-999999, Emax=999999, capitals=1, clamp=0, flags=
从上面的结果中我们可以看到 prec=28
,这就是默认的精度,我们可以使用 getcontext().prec = xxx
来重新设置精度。接下来通过具体示例看一下。
基本运算
import decimal d1 = decimal.Decimal(1.1) d2 = decimal.Decimal(9.9) print(d1 + d2) print(d1 - d2) print(d1 * d2) print(d1 / d2)
执行结果:
11.00000000000000044408920985 -8.800000000000000266453525910 10.89000000000000127009514017 0.1111111111111111160952773272
上面结果是用了默认精度,我们重新设置下精度再来看一下:
import decimal decimal.getcontext().prec = 2 d1 = decimal.Decimal(1.1) d2 = decimal.Decimal(9.9) print(d1 + d2) print(d1 - d2) print(d1 * d2) print(d1 / d2)
执行结果:
11 -8.8 11 0.11