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

代码结果:

012
01.02.03.0
1NaNNaN2.0
2NaNNaNNaN
38.08.0NaN
  • 默认滤除所有包含NaN:
df1.dropna()

代码结果:

012
01.02.03.0
  • 传入**how=‘all’**滤除全为NaN的行:
df1.dropna(how='all')

代码结果:

012
01.02.03.0
1NaNNaN2.0
38.08.0NaN
  • 传入axis=1滤除列:
df1[3]=NaN
df1

代码结果:

0123
01.02.03.0NaN
1NaNNaN2.0NaN
2NaNNaNNaNNaN
38.08.0NaNNaN
df1.dropna(axis=1,how="all")

代码结果:

012
01.02.03.0
1NaNNaN2.0
2NaNNaNNaN
38.08.0NaN
  • 传入thresh=n保留至少有n个非NaN数据的行:
df1.dropna(thresh=1)

代码结果:

0123
01.02.03.0NaN
1NaNNaN2.0NaN
38.08.0NaNNaN
df1.dropna(thresh=3)

代码结果:

0123
01.02.03.0NaN

谢谢大家的浏览,
希望我的努力能帮助到您,
共勉!

  • 48
    点赞
  • 122
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值