在我们开发工作中浮点类型的使用还是比较普遍的,对于一些涉及资金金额的计算更是不能有丝毫误差,Python 的 decimal 模块为浮点型精确计算提供了支持。
1 简介
decimal 模块设计以十进制数、算术上下文和信号这三个概念为中心。十进制数是不可变的,它有一个符号,系数数字和一个指数,为了保持重要性,系数数字不会截断尾随零,十进制数也有特殊值,如:Infinity、-Infinity 和 NaN;算术上下文是指定精度、舍入规则、指数限制、指示操作结果的标志以及确定符号是否被视为异常的陷阱启用器的环境;信号是在计算过程中出现的异常条件组。对于 decimal 模块的设计原则,我们只需简单了解即可。
2 快速上手
Decimal
我们看一下 Decimal 实例的基本使用。示例如下:
1 |
|
使用 getcontext().prec 设定有效数字。示例如下:
1 |
|
设置小数位数。示例如下:
1 |
|
转成字符串。示例如下:
1 |
|
adjusted()
在移出系数最右边的数字之后返回调整后的指数,直到只剩下前导数字,该函数用于确定最高有效位相对于小数点的位置。示例如下:
1 |
|
compare(other, context=None)
比较两个 Decimal 实例的值。示例如下:
1 |
|
copy_abs()
返回参数的绝对值。示例如下:
1 |
|
is_normal(context=None)
如果参数是一个有限正规数,返回 True,如果参数是 0、次正规数、无穷大或是 NaN,返回 False。示例如下:
1 |
|
is_zero()
如果参数是 0,则返回 True,否则返回 False。示例如下:
1 |
|
ln(context=None)
返回操作数的自然对数(以 e 为底)。示例如下:
1 |
|
log10(context=None)
返回操作数的自然对数(以 10 为底)。示例如下:
1 |
|
max(other, context=None)
比较两个数值大小,并返回大的值。示例如下:
1 |
|
max_mag(other, context=None)
比较两个数绝对值大小,并返回绝对值大的值。示例如下:
1 |
|
min(other, context=None)
比较两个数值大小,并返回小的值。示例如下:
1 |
|
min_mag(other, context=None)
比较两个数绝对值大小,并返回绝对值小的值。示例如下:
1 |
|
is_signed()
如果参数带有负号,则返回为 True,否则返回 False。示例如下:
1 |
|
总结
本节给大家介绍了 decimal 模块的一些概念和基本使用,对 Python 工程师使用 decimal 模块提供了支撑。
参考: