Python Pandas对缺失值的处理方法


Posted in Python onSeptember 27, 2019

Pandas使用这些函数处理缺失值:

  • isnull和notnull:检测是否是空值,可用于df和series
  • dropna:丢弃、删除缺失值
    • axis : 删除行还是列,{0 or ‘index', 1 or ‘columns'}, default 0
    • how : 如果等于any则任何值为空都删除,如果等于all则所有值都为空才删除
    • inplace : 如果为True则修改当前df,否则返回新的df
  • fillna:填充空值
    • value:用于填充的值,可以是单个值,或者字典(key是列名,value是值)
    • method : 等于ffill使用前一个不为空的值填充forword fill;等于bfill使用后一个不为空的值填充backword fill
    • axis : 按行还是列填充,{0 or ‘index', 1 or ‘columns'}
    • inplace : 如果为True则修改当前df,否则返回新的df
import pandas as pd

实例:特殊Excel的读取、清洗、处理

步骤1:读取excel的时候,忽略前几个空行

studf = pd.read_excel("./datas/student_excel/student_excel.xlsx", skiprows=2)
studf

Unnamed: 0 姓名 科目 分数
0 NaN 小明 语文 85.0
1 NaN NaN 数学 80.0
2 NaN NaN 英语 90.0
3 NaN NaN NaN NaN
4 NaN 小王 语文 85.0
5 NaN NaN 数学 NaN
6 NaN NaN 英语 90.0
7 NaN NaN NaN NaN
8 NaN 小刚 语文 85.0
9 NaN NaN 数学 80.0
10 NaN NaN 英语 90.0

步骤2:检测空值

studf.isnull()

Unnamed: 0 姓名 科目 分数
0 True False False False
1 True True False False
2 True True False False
3 True True True True
4 True False False False
5 True True False True
6 True True False False
7 True True True True
8 True False False False
9 True True False False
10 True True False False
studf["分数"].isnull()
0 False
1 False
2 False
3 True
4 False
5 True
6 False
7 True
8 False
9 False
10 False
Name: 分数, dtype: bool
studf["分数"].notnull()
0 True
1 True
2 True
3 False
4 True
5 False
6 True
7 False
8 True
9 True
10 True
Name: 分数, dtype: bool
# 筛选没有空分数的所有行
studf.loc[studf["分数"].notnull(), :]

Unnamed: 0 姓名 科目 分数
0 NaN 小明 语文 85.0
1 NaN NaN 数学 80.0
2 NaN NaN 英语 90.0
4 NaN 小王 语文 85.0
6 NaN NaN 英语 90.0
8 NaN 小刚 语文 85.0
9 NaN NaN 数学 80.0
10 NaN NaN 英语 90.0

步骤3:删除掉全是空值的列

studf.dropna(axis="columns", how='all', inplace=True)
studf

姓名 科目 分数
0 小明 语文 85.0
1 NaN 数学 80.0
2 NaN 英语 90.0
3 NaN NaN NaN
4 小王 语文 85.0
5 NaN 数学 NaN
6 NaN 英语 90.0
7 NaN NaN NaN
8 小刚 语文 85.0
9 NaN 数学 80.0
10 NaN 英语 90.0

步骤4:删除掉全是空值的行

studf.dropna(axis="index", how='all', inplace=True)
studf

姓名 科目 分数
0 小明 语文 85.0
1 NaN 数学 80.0
2 NaN 英语 90.0
4 小王 语文 85.0
5 NaN 数学 NaN
6 NaN 英语 90.0
8 小刚 语文 85.0
9 NaN 数学 80.0
10 NaN 英语 90.0

步骤5:将分数列为空的填充为0分

studf.fillna({"分数":0})

姓名 科目 分数
0 小明 语文 85.0
1 NaN 数学 80.0
2 NaN 英语 90.0
4 小王 语文 85.0
5 NaN 数学 0.0
6 NaN 英语 90.0
8 小刚 语文 85.0
9 NaN 数学 80.0
10 NaN 英语 90.0
# 等同于
studf.loc[:, '分数'] = studf['分数'].fillna(0)
studf

姓名 科目 分数
0 小明 语文 85.0
1 NaN 数学 80.0
2 NaN 英语 90.0
4 小王 语文 85.0
5 NaN 数学 0.0
6 NaN 英语 90.0
8 小刚 语文 85.0
9 NaN 数学 80.0
10 NaN 英语 90.0

步骤6:将姓名的缺失值填充

使用前面的有效值填充,用ffill:forward fill

studf.loc[:, '姓名'] = studf['姓名'].fillna(method="ffill")
studf

姓名 科目 分数
0 小明 语文 85.0
1 小明 数学 80.0
2 小明 英语 90.0
4 小王 语文 85.0
5 小王 数学 0.0
6 小王 英语 90.0
8 小刚 语文 85.0
9 小刚 数学 80.0
10 小刚 英语 90.0

步骤7:将清洗好的excel保存

studf.to_excel("./datas/student_excel/student_excel_clean.xlsx", index=False)

总结

以上就是我在处理客户端真实IP的方法,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对三水点靠木的支持。

Python 相关文章推荐
python3设计模式之简单工厂模式
Oct 17 Python
Python SQLite3简介
Feb 22 Python
python+selenium实现QQ邮箱自动发送功能
Jan 23 Python
对python pandas读取剪贴板内容的方法详解
Jan 24 Python
Python进阶之全面解读高级特性之切片
Feb 19 Python
解决使用export_graphviz可视化树报错的问题
Aug 09 Python
Python的bit_length函数来二进制的位数方法
Aug 27 Python
python 读取数据库并绘图的实例
Dec 03 Python
scrapy-redis分布式爬虫的搭建过程(理论篇)
Sep 29 Python
python字典通过值反查键的实现(简洁写法)
Sep 30 Python
如何用Python提取10000份log中的产品信息
Jan 14 Python
Pytorch之扩充tensor的操作
Mar 04 Python
Python 可变类型和不可变类型及引用过程解析
Sep 27 #Python
Python操作qml对象过程详解
Sep 26 #Python
python 字典的打印实现
Sep 26 #Python
手把手教你pycharm专业版安装破解教程(linux版)
Sep 26 #Python
QML使用Python的函数过程解析
Sep 26 #Python
python 怎样将dataframe中的字符串日期转化为日期的方法
Sep 26 #Python
python3多线程知识点总结
Sep 26 #Python
You might like
PHP验证类的封装与使用方法详解
2019/01/10 PHP
流量统计器如何鉴别C#:WebBrowser中伪造referer
2015/01/07 Javascript
javascript获得当前的信息的一些常用命令
2015/02/25 Javascript
实现前后端数据交互方法汇总
2015/04/07 Javascript
JavaScript中exec函数用法实例分析
2015/06/08 Javascript
JavaScript编写简单的计算器
2015/11/25 Javascript
js遮罩效果制作弹出注册界面效果
2017/01/25 Javascript
关于Node.js的events.EventEmitter用法介绍
2017/04/01 Javascript
node.js+jQuery实现用户登录注册AJAX交互
2017/04/28 jQuery
利用vueJs实现图片轮播实例代码
2017/06/03 Javascript
js canvas实现简单的图像扩散效果
2020/06/28 Javascript
基于Bootstrap实现城市三级联动
2017/11/23 Javascript
利用原生JavaScript实现造日历轮子实例代码
2019/05/08 Javascript
Vue 自定义标签的src属性不能使用相对路径的解决
2019/09/17 Javascript
python 列表删除所有指定元素的方法
2018/04/19 Python
python使用Flask操作mysql实现登录功能
2018/05/14 Python
实例讲解Python爬取网页数据
2018/07/08 Python
Python实现的旋转数组功能算法示例
2019/02/23 Python
Python之指数与E记法的区别详解
2019/11/21 Python
css3 实现元素弧线运动的示例代码
2020/04/24 HTML / CSS
HTML5之SVG 2D入门11—用户交互性(动画)介绍及应用
2013/01/30 HTML / CSS
Public Desire美国/加拿大:全球性的在线鞋类品牌
2018/12/17 全球购物
意大利网上药房:Farmacia 33
2020/01/27 全球购物
Can a struct inherit from another class? (结构体能继承类吗)
2014/07/22 面试题
法律专业应届本科毕业生求职信
2013/10/25 职场文书
后勤部经理岗位职责
2014/02/23 职场文书
物业总经理岗位职责
2014/02/28 职场文书
数控机床专业自荐信
2014/05/19 职场文书
投标承诺书怎么写
2014/05/24 职场文书
委托书格式
2014/08/01 职场文书
2016入党积极分子心得体会
2016/01/06 职场文书
劳动合同变更协议书范本
2019/04/18 职场文书
缓存替换策略及应用(以Redis、InnoDB为例)
2021/07/25 Redis
SQL实现LeetCode(176.第二高薪水)
2021/08/04 MySQL
Win7/8.1用户可以免费升级到Windows 11系统吗?
2021/11/21 数码科技
Redis入门基础常用操作命令整理
2022/06/01 Redis