欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

python2與python3中關(guān)于對(duì)NaN類型數(shù)據(jù)的判斷和轉(zhuǎn)換方法

 更新時(shí)間:2018年10月30日 10:00:33   作者:敲代碼的quant  
今天小編就為大家分享一篇python2與python3中關(guān)于對(duì)NaN類型數(shù)據(jù)的判斷和轉(zhuǎn)換方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧

今天在對(duì)一堆新數(shù)據(jù)進(jìn)行數(shù)據(jù)清洗的時(shí)候,遇到了一個(gè)這樣的問題:

ValueError: cannot convert float NaN to integer 

一開始是這樣的,我用的jupyter是python35的,使用DataFrame讀入了數(shù)據(jù),其中有一列是year,默認(rèn)讀入時(shí)是將year這一列轉(zhuǎn)換為了float,所以就有了這樣的現(xiàn)象:

python2 python3 對(duì)NaN類型數(shù)據(jù)的判斷和轉(zhuǎn)換

年份都是float類型了,看得我強(qiáng)迫癥都犯了。于是通過這樣的代碼來進(jìn)行強(qiáng)轉(zhuǎn),于是就報(bào)了上面的錯(cuò)誤了。

df.year = [int(y) for y in df.year]

簡(jiǎn)單描述一下問題,其實(shí)就是NaN在python35中無法被強(qiáng)轉(zhuǎn)。

首先說一下,NaN類型在python25中在強(qiáng)轉(zhuǎn)int的時(shí)候默認(rèn)是轉(zhuǎn)換為0的,而在python25之后的版本再進(jìn)行轉(zhuǎn)換的時(shí)候就會(huì)報(bào)以上的錯(cuò)誤。

我們先打印看一下np.nan的類型:

print(type(np.nan))
<type 'float'>

np.nan是float類型,但是在進(jìn)行int轉(zhuǎn)換的時(shí)候就會(huì)報(bào)錯(cuò)。

解決方法:

使用is或者==進(jìn)行判斷是不是NaN,不是NaN進(jìn)行強(qiáng)轉(zhuǎn)int,是則用0代替。

先說一下==和is使用時(shí)的區(qū)別:

is和==都是對(duì)對(duì)象進(jìn)行比較判斷作用的,但對(duì)對(duì)象比較判斷的內(nèi)容并不相同。

如果有a跟b兩個(gè)變量,只有數(shù)值型和字符串型的情況下,a is b才為True,當(dāng)a和b是tuple,list,dict、set或者是實(shí)例化對(duì)象時(shí),a is b為False。

==是python標(biāo)準(zhǔn)操作符中的比較操作符,用來比較判斷兩個(gè)對(duì)象的value(值)是否相等。

通過下面的代碼可以看出,np.nan==np.nan結(jié)果是False,但是np.nan is np.nan卻是True。

a = np.nan
 
 
print(a == np.nan)
print(a == a)
print(a is np.nan)
print(a is a)
 
 
False
False
True
True

因此,通過每個(gè)元素與自身比較就可以解決了,代碼如下:

year = []
for y in df.year:
 if y == y:
  year.append(int(y))
 else:
  year.append(0)

以上這篇python2與python3中關(guān)于對(duì)NaN類型數(shù)據(jù)的判斷和轉(zhuǎn)換方法就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • python遍歷文件夾找出文件夾后綴為py的文件方法

    python遍歷文件夾找出文件夾后綴為py的文件方法

    今天小編就為大家分享一篇python遍歷文件夾找出文件夾后綴為py的文件方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2018-10-10
  • 對(duì)pandas通過索引提取dataframe的行方法詳解

    對(duì)pandas通過索引提取dataframe的行方法詳解

    今天小編就為大家分享一篇對(duì)pandas通過索引提取dataframe的行方法詳解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2019-02-02
  • python中的import語句用法大全

    python中的import語句用法大全

    import語句用來導(dǎo)入其他python文件(稱為模塊module),使用該模塊里定義的類、方法或者變量,從而達(dá)到代碼復(fù)用的目的,文中給大家提到import 語句的兩種格式通過示例代碼介紹的很詳細(xì),需要的朋友參考下吧
    2021-07-07
  • numpy.random.seed()的使用實(shí)例解析

    numpy.random.seed()的使用實(shí)例解析

    這篇文章主要介紹了numpy.random.seed()的使用實(shí)例解析,分享了相關(guān)代碼示例,小編覺得還是挺不錯(cuò)的,具有一定借鑒價(jià)值,需要的朋友可以參考下
    2018-02-02
  • Python GUI學(xué)習(xí)之登錄系統(tǒng)界面篇

    Python GUI學(xué)習(xí)之登錄系統(tǒng)界面篇

    這篇文章主要介紹了Python GUI學(xué)習(xí)之登錄系統(tǒng)界面篇,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-08-08
  • python里讀寫excel等數(shù)據(jù)文件的6種常用方式(小結(jié))

    python里讀寫excel等數(shù)據(jù)文件的6種常用方式(小結(jié))

    這篇文章主要介紹了python里讀寫excel等數(shù)據(jù)文件的6種常用方式(小結(jié)),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-04-04
  • python Pillow圖像處理方法匯總

    python Pillow圖像處理方法匯總

    這篇文章主要介紹了python Pillow圖像處理方法匯總,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-10-10
  • 如何使用Python連接?SSH?服務(wù)器并執(zhí)行命令

    如何使用Python連接?SSH?服務(wù)器并執(zhí)行命令

    實(shí)際開發(fā)中,有時(shí)候經(jīng)常需要查看日志,有時(shí)候使用ssh工具打開就為了看一下錯(cuò)誤日志又比較麻煩,所以今天帶來一個(gè)簡(jiǎn)單的基于python的小工具,感興趣的朋友跟隨小編一起看看吧
    2023-11-11
  • PyQt編程之如何在屏幕中央顯示窗體的實(shí)例

    PyQt編程之如何在屏幕中央顯示窗體的實(shí)例

    今天小編就為大家分享一篇PyQt編程之如何在屏幕中央顯示窗體的實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2019-06-06
  • Python?argparse庫(kù)的基本使用步驟

    Python?argparse庫(kù)的基本使用步驟

    argparse庫(kù)是python下的一個(gè)命令行參數(shù)管理庫(kù),支持int、str、float、bool、數(shù)組等5種基本數(shù)據(jù)類型,這篇文章主要介紹了Python?argparse庫(kù)的基本使用,需要的朋友可以參考下
    2022-07-07

最新評(píng)論