1. 程式人生 > 實用技巧 >python 高精度浮點數計算模組decimal

python 高精度浮點數計算模組decimal

Pythondecimal

1、簡單使用:保留三位小數

>>>Decimal('1.41421356').quantize(Decimal('1.000'))
Decimal('1.414')

2、簡單使用:保留兩位小數

>>> from decimal import Decimal
>>> Decimal('0.125').quantize(Decimal('0.00'))
Decimal('0.12')
>>> Decimal('0.375').quantize(Decimal('0.00'))
Decimal('0.38')

注意:為什麼0.125不是四捨五入。

3、檢視預設進位方式:預設進位方式為奇進偶舍

>>> from decimal import getcontext
>>> getcontext().rounding
'ROUND_HALF_EVEN'

4、設定進位方式為四捨五入

>>> from decimal import Decimal, ROUND_HALF_UP
>>> Decimal('0.375').quantize(Decimal('0.00'), rounding=ROUND_HALF_UP)
Decimal('0.38')
>>> Decimal('
0.125').quantize(Decimal('0.00'), rounding=ROUND_HALF_UP) Decimal('0.13')

最後注意:可以傳遞給Decimal整型或者字串引數,但不能是浮點資料,因為浮點資料本身就不準確。

from decimal import Decimal,ROUND_HALF_UP

a =11.245
origin_num = Decimal(str(a))
answer_num1 = origin_num.quantize(Decimal('0.00'), rounding=ROUND_HALF_UP)
print(answer_num1)

origin_num1 
=Decimal(a) answer_num2 = origin_num1.quantize(Decimal('0.00'), rounding=ROUND_HALF_UP) print(answer_num2)

輸出:

11.25
11.24