Pandas詳解十之Dropna濾除缺失數據

約定:

import pandas as pd
import numpy as np
from numpy import nan as NaN

濾除缺失數據

pandas的設計目標之一就是使得處理缺失數據的任務更加輕鬆些。pandas使用NaN作爲缺失數據的標記。

使用dropna使得濾除缺失數據更加得心應手。

一、處理Series對象

  • 通過**dropna()**濾除缺失數據:
se1=pd.Series([4,NaN,8,NaN,5])
print(se1)
se1.dropna()

代碼結果:

0    4.0
1    NaN
2    8.0
3    NaN
4    5.0
dtype: float64

0    4.0
2    8.0
4    5.0
dtype: float64
  • 通過布爾序列也能濾除:
se1[se1.notnull()]

代碼結果:

0    4.0
2    8.0
4    5.0
dtype: float64

二、處理DataFrame對象

處理DataFrame對象比較複雜,因爲你可能需要丟棄所有的NaN或部分NaN。

df1=pd.DataFrame([[1,2,3],[NaN,NaN,2],[NaN,NaN,NaN],[8,8,NaN]])
df1

代碼結果:

0 1 2
0 1.0 2.0 3.0
1 NaN NaN 2.0
2 NaN NaN NaN
3 8.0 8.0 NaN
  • 默認濾除所有包含NaN:
df1.dropna()

代碼結果:

0 1 2
0 1.0 2.0 3.0
  • 傳入**how=‘all’**濾除全爲NaN的行:
df1.dropna(how='all')

代碼結果:

0 1 2
0 1.0 2.0 3.0
1 NaN NaN 2.0
3 8.0 8.0 NaN
  • 傳入axis=1濾除列:
df1[3]=NaN
df1

代碼結果:

0 1 2 3
0 1.0 2.0 3.0 NaN
1 NaN NaN 2.0 NaN
2 NaN NaN NaN NaN
3 8.0 8.0 NaN NaN
df1.dropna(axis=1,how="all")

代碼結果:

0 1 2
0 1.0 2.0 3.0
1 NaN NaN 2.0
2 NaN NaN NaN
3 8.0 8.0 NaN
  • 傳入thresh=n保留至少有n個非NaN數據的行:
df1.dropna(thresh=1)

代碼結果:

0 1 2 3
0 1.0 2.0 3.0 NaN
1 NaN NaN 2.0 NaN
3 8.0 8.0 NaN NaN
df1.dropna(thresh=3)

代碼結果:

0 1 2 3
0 1.0 2.0 3.0 NaN

謝謝大家的瀏覽,
希望我的努力能幫助到您,
共勉!

發佈了48 篇原創文章 · 獲贊 181 · 訪問量 34萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章