python中浮點數(shù)比較判斷!為什么不能用==(推薦)
問題:浮點數(shù)比較為什么不能用==來寫?
答:計算機里面的數(shù)字是由二進制保存的,在計算機內(nèi)部有些數(shù)字不能準確的保存,于是就保存了一個最靠近的數(shù)字。
計算機表示浮點數(shù)(float或double類型)都有一個精度限制,對于超出了精度限制的浮點數(shù),計算機會把它們的精度之外的小數(shù)部分截斷。
因此比較兩個float是否相等,不能僅僅依靠==來判斷,而是當他們的兩者的差值小于一個我們可以容忍的小值時,就可以認為它們相等。
解決辦法:
1、在python3.5之前,可以通過計算兩個浮點數(shù)之差來判斷兩個浮點數(shù)是否相等:
例子1: abs(f1 - f2) <= allowed_error 可接受的誤差
或:
def isclose(a, b, rel_tol=1e-09, abs_tol=0.0): return abs(a-b) <= max(rel_tol * max(abs(a), abs(b)), abs_tol)
2、python 3.5之后,PEP485提案中給出了解決方案。math模塊新增一個isclose函數(shù)用來判斷兩個浮點數(shù)的值是否接近或相等 例子2:
- 源碼:
isclose(a, b, *, rel_tol=1e-09, abs_tol=0.0)
- 參數(shù):
- a,b:兩個需要比較的浮點數(shù);
- rel_tol: 相對于輸入值的大小,被認為是“接近”的最大差異;
- abs_tol: 無論輸入值的大小,被認為“接近”的最大差異
- 本質(zhì)算法
<strong><code> abs(a-b) <= max(rel_tol * max(abs(a), abs(b)), abs_tol)</code></strong>
import math print(math.isclose(2.1,2.2,rel_tol=0.1)) # 結(jié)果:True # 同理abs_tol也可以自定義
到此這篇關(guān)于python中浮點數(shù)比較判斷!為什么不能用==的文章就介紹到這了,更多相關(guān)python浮點數(shù)比較內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Python爬取門戶論壇評論淺談Python未來發(fā)展方向
這篇文章主要介紹了如何實現(xiàn)Python爬取門戶論壇評論,附含圖片示例代碼,講解了詳細的操作過程,有需要的的朋友可以借鑒參考下,希望可以有所幫助2021-09-09Python排序方法中sort和sorted的區(qū)別詳解
在python中常用的排序函數(shù)就是sort()和sorted()這兩個函數(shù),使用 sort() 或內(nèi)建函數(shù) sorted() 對列表進行排序,本文將詳細介紹sorted和sort兩者之間的區(qū)別,感興趣的可以了解一下2023-08-08Python實現(xiàn)Opencv cv2.Canny()邊緣檢測
這篇博客將介紹Canny邊緣檢測的概念,并利用cv2.Canny()實現(xiàn)邊緣檢測,具有一定的參考價值,感興趣的小伙伴們可以參考一下2021-07-07