今天在用寫一段求和的代碼時候,發現最後返回的是nan的結果,這段循環求和代碼依次調用了三個函數,因而依次打印這三個函數的返回值,發現其中一個函數的返回值爲nan,原來是由於這段函數裏面沒有類似的用戶,全部返回結果爲nan,因而我就想加一個判斷條件,當結果爲空時,跳過本次循環:函數
if res==nan: continue
本覺得加上這一句話就能夠了,因而從新運行了一下,oh,shit!!!!結果沒有任何變化,之前是nan的仍是同樣沒有跳過。因而我想到了我用到了Python的numpy庫,會不會是numpy下的nan類型呢,因而修改一下判斷條件:測試
if res==np.nan: continue
從新運行!仍是不對。spa
找到原函數的位置,打印一下產生nan類型:code
>>print(type(res)) <class 'numpy.float64'>
發現屬於numpy.float64類型,沒辦法,我想要不把原來函數的返回值改成float型吧,因而找到原函數,修改:ci
return float(res)
而後在循環求和的代碼段中加上:it
if res==nan: continue
運行!gg 仍是不行!table
沒辦法。爲了找到真兇,我只能拿出res挨着測試:ast
1class 2import 3 4 5 6 7 8 9 10 11 12 13 14 15 16 |
|
天哪!這個nan究竟是什麼類型!
最後忽然想到了py自帶的math庫下面好像有一個判斷nan的函數——isnan,抱着必死的心態,試了試:
>>from math import isnan >>isnan(res) True
Wooooooo!True! 終於找到辦法了!天哪!終於解決了,這一個小問題糾結了我一中午。。。
轉載的文章 當時幫了特大忙 先謝一下
技術小白,遇到問題,多嘗試!