在numpy或pandas下,同样的type,为啥 0.0/0.0 有时能=NaN 有时能=inf?
这是 知乎上看到的题目 ,挺有意思的,可还没人回答,搬过来大家看看。
原标题:在numpy或pandas下,同样的type(float16或int16),为啥 0.0/0.0 有时能 =NaN 有时能 =inf?
这个和前面一个问题很像,但是这次重点我想知道,各种情况下输出不同的原因。
请听题:
我有个python pandas的表
time q v k
2015-4-1 8:00 0 0
2015-4-1 8:00 16 42
2015-4-1 8:00 14 59
... ...... ...... ...... ...... ...
Now I want let k=q/v if v!=0 else k=0. This is how I did:
(因为里面有日文在别的col里,所以用的encoding=shift-jis,导致 **type 都是 object**)
>>>df['k'] = df['q'].astype(float16) /df['v'].astype(float16)
q v k
0 0 NaN
>>>df['k'][df['v']==0] = 0.0
(更好的方法您能分享吗?)
只有我让
k,q
都是 float16 时, 上面 0/0 is NaN.
可是:
>>>0/np.float64(0)
nan
>>>df['k'] = df['q'] /df['v'].astype(float16)
ZeroDivisionError
也就是
0/float16(0)=nan
但是换到pandas里就不行
再来:
>>> df['k'] = df['q'].astype(int16)/df['v'].astype(int16)
q v k
0 0 inf
>>> np.int64(0)/np.int64(0)
nan
也就是
int16(0)/int16(0)=nan
但是换到pandas里就是inf
。。。
还没完:
>>>df =pd.DataFrame({'q':[0,16,14],'v':[0,42,59]})
>>>df.astype('float64')
>>>df['k']=df.q/df.v
q v k
0 0 inf
也就是 把整个dataframe给变float16以后竟然也能出inf 。。。
这都是为啥啊?
史莱姆大贤者
10 years ago