您好,登錄后才能下訂單哦!
這篇文章主要介紹了Python中的數據精度問題怎么解決的相關知識,內容詳細易懂,操作簡單快捷,具有一定借鑒價值,相信大家閱讀完這篇Python中的數據精度問題怎么解決文章都會有所收獲,下面我們一起來看看吧。
在Python中(其他語言中也存在這個問題,這是計算機采用二進制導致的),有時候由于二進制和十進制之間對應問題會導致數值的精度問題,比如無法用有限個二進制位完整地表示0.1,因為0.1轉化為二進制之后位一個無限循環小數
print(1.1*2.2)
查看運行結果:
需要將整數部分與小數部分單獨做處理可以解決
def multiple(m1, m2): r='' ## 若存在浮點型,則先轉化為整數 if type( m1 )==float or type( m2 )==float: print( "存在浮點數" ) len_m1=len( str( m1 ).split( "." )[1] ) len_m2=len( str( m2 ).split( "." )[1] ) print( "m1的小數位:", len_m1 ) print( "m2的小數位:", len_m2 ) m1=int( 10**len_m1*m1 ) m2=int( 10**len_m2*m2 ) print( "m1化為整數:", m1 ) print( "m2化為整數:", m2 ) r=str( m1*m2 ) print( "r:", r ) l=len_m1+len_m2 print( "l的總長度:", l ) if l<len( r ): r_front=r[:-l] r_last=r[-l:] print( r_front, "-", r_last ) r=r_front+"."+r_last else: r="0."+(l-len( r ))*"0"+r else: print( "不存在浮點數" ) r=m1*m2 return r res = multiple(1.1,2.2) print(res)
查看運行結果:
歸根結底是計算機存儲浮點數的問題
a1 = 0.235 a2 = round(a1,2) a3 = '%.2f' % a1 print(a2) print(a3)
查看運行結果:
需要將float轉換為Decimal,該類可以通過接受字符串(務必是字符串)形式的浮點數實現相對精確的小數計算(減緩了精度誤差,但沒有消滅)
from decimal import Decimal a1 = 0.235 a2 = Decimal(str(a1)).quantize(Decimal("0.00")) a3 = '{:.2f}'.format(Decimal(str(a1))) print(a2) print(a3)
查看運行結果:
關于“Python中的數據精度問題怎么解決”這篇文章的內容就介紹到這里,感謝各位的閱讀!相信大家對“Python中的數據精度問題怎么解決”知識都有一定的了解,大家如果還想學習更多知識,歡迎關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。