python中decimal用法详解

Python的decimal模块提供了用于高精度十进制浮点运算的功能,支持用户自定义精度,例如四舍五入。示例展示了如何创建和操作Decimal对象,包括加法、设置精度以及处理特殊值如NaN和Infinity。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

decimal是python内置库。

decimal模块支持快速正确四舍五入的十进制浮点运算。

示例代码:

import decimal

a = decimal.Decimal(123)
print(a)

b = decimal.Decimal(123456.123)
print(b)
print(a + b)

c = decimal.Decimal('123456.123')
print(a + c)

aa = 123
bb = 123456.123
print(aa + bb)

运行结果:

        与基于硬件的二进制浮点数不同,decimal 模块具有用户可更改的精度(默认为 28 位),对于给定问题,它可以根据需要设置为最大:

from decimal import getcontext, Decimal

getcontext().prec = 6
a = Decimal(1)
b = Decimal(7)
print(a)
print(b)
print(a / b)

getcontext().prec = 28
c = Decimal(1)
d = Decimal(7)
print(c)
print(d)
print(c / d)

运行结果:

        使用小数的通常开始是导入模块,查看当前上下文getcontext(),并在必要时为精度、舍入或启用的陷阱设置新值:

from decimal import getcontext

print(getcontext())
getcontext().prec = 6
print(getcontext())

运行结果:

        Decimal 实例可以从整数、字符串、浮点数或元组构造。从整数或浮点数构造执行该整数或浮点数的值的精确转换。十进制数包括特殊值,例如 NaN代表“不是数字”、正数和负数 Infinity,以及-0:

from decimal import getcontext, Decimal

getcontext().prec = 6
print(getcontext())
a = Decimal(10)
print(a, type(a))

b = Decimal(3.14)
print(b)

c = Decimal('3.14')
print(c)

d, e, f, g = Decimal((0, (3, 1, 4), -2)), Decimal((0, (3, 1, 4), -5)), Decimal((1, (3, 1, 4), -5)), Decimal((0, (3, 1, 4), 5))
print(d, e, f, g)

h = Decimal('NaN')
print(h, type(h))

i = Decimal('-Infinity')
print(i, type(i))

运行结果:

官方文档:decimal — Decimal fixed point and floating point arithmetic — Python 3.11.2 documentation

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值