今天在用寫一段求和的代碼時候,發現最后返回的是nan的結果,這段循環求和代碼依次調用了三個函數,於是依次打印這三個函數的返回值,發現其中一個函數的返回值為nan,原來是因為這段函數里面沒有相似的用戶,所有返回結果為nan,於是我就想加一個判斷條件,當結果為空時,跳過本次循環:
if res==nan: continue
本以為加上這一句話就可以了,於是重新運行了一下,oh,shit!!!!結果沒有任何變化,以前是nan的還是一樣沒有跳過。於是我想到了我用到了Python的numpy庫,會不會是numpy下的nan類型呢,於是修改一下判斷條件:
if res==np.nan: continue
重新運行!還是不對。
找到原函數的位置,打印一下產生nan類型:
>>print(type(res)) <class 'numpy.float64'>
發現屬於numpy.float64類型,沒辦法,我想要不把原來函數的返回值改為float型吧,於是找到原函數,修改:
return float(res)
然后在循環求和的代碼段中加上:
if res==nan: continue
運行!gg 還是不行!
沒辦法。為了找到真凶,我只能拿出res挨着測試:
>>res=np.nan False >>res=nan False >>res='NaN' False >>res=float('NaN') False >>> isNaN(res) Traceback (most recent call last): File "<stdin>", line 1, in <module> NameError: name 'isNaN' is not defined
天哪!這個nan到底是什么類型!
最后突然想到了py自帶的math庫下面好像有一個判斷nan的函數——isnan,抱着必死的心態,試了試:
>>from math import isnan >>isnan(res) True
Wooooooo!True! 終於找到辦法了!天哪!終於解決了,這一個小問題糾結了我一中午。。。
技術小白,遇到問題,多嘗試!