Python 实现将numpy中的nan和inf,nan替换成对应的均值


Posted in Python onJune 08, 2020

nan:not a number

inf:infinity;正无穷

numpy中的nan和inf都是float类型

Python 实现将numpy中的nan和inf,nan替换成对应的均值

t!=t 返回bool类型的数组(矩阵)

np.count_nonzero() 返回的是数组中的非0元素个数;true的个数。

np.isnan() 返回bool类型的数组。

那么问题来了,在一组数据中单纯的把nan替换为0,合适么?会带来什么样的影响?

比如,全部替换为0后,替换之前的平均值如果大于0,替换之后的均值肯定会变小,所以更一般的方式是把缺失的数值替换为均值(中值)或者是直接删除有缺失值的一行

demo.py(numpy,将数组中的nan替换成对应的均值):

# coding=utf-8
import numpy as np
 
def fill_ndarray(t1):
 for i in range(t1.shape[1]): # 遍历每一列(每一列中的nan替换成该列的均值)
 temp_col = t1[:, i] # 当前的一列
 nan_num = np.count_nonzero(temp_col != temp_col)
 if nan_num != 0: # 不为0,说明当前这一列中有nan
  temp_not_nan_col = temp_col[temp_col == temp_col] # 去掉nan的ndarray
 
  # 选中当前为nan的位置,把值赋值为不为nan的均值
  temp_col[np.isnan(temp_col)] = temp_not_nan_col.mean() # mean()表示求均值。
 return t1
 
if __name__ == '__main__':
 t1 = np.array([[ 0., 1., 2., 3., 4., 5.],
   [ 6., 7., np.nan, np.nan, np.nan, np.nan],
   [12., 13., 14., 15., 16., 17.],
   [18., 19., 20., 21., 22., 23.]])
 
 t1 = fill_ndarray(t1) # 将nan替换成对应的均值
 print(t1)
 '''
 [[ 0. 1. 2. 3. 4. 5.]
 [ 6. 7. 12. 13. 14. 15.]
 [12. 13. 14. 15. 16. 17.]
 [18. 19. 20. 21. 22. 23.]]
 '''

补充知识:numpy对数组求平均时如何忽略nan值

前言:在对numpy数组求平均np.mean()或者求数组中最大最小值np.max()/np.min()时,如果数组中有nan,此时求得的结果为:nan,那么该如何忽略其中的nan呢?此时应该用另一个方法:np.nanmean(),np.nanmax(),np.nanmin().

使用np.mean()的效果

Python 实现将numpy中的nan和inf,nan替换成对应的均值

使用np.nanmean()的效果

Python 实现将numpy中的nan和inf,nan替换成对应的均值

以上这篇Python 实现将numpy中的nan和inf,nan替换成对应的均值就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Python 相关文章推荐
Python笔记(叁)继续学习
Oct 24 Python
python实现超简单端口转发的方法
Mar 13 Python
windows下python连接oracle数据库
Jun 07 Python
python 递归遍历文件夹,并打印满足条件的文件路径实例
Aug 30 Python
Ubuntu16.04/树莓派Python3+opencv配置教程(分享)
Apr 02 Python
python自动查询12306余票并发送邮箱提醒脚本
May 21 Python
Python实现的序列化和反序列化二叉树算法示例
Mar 02 Python
python 使用三引号时容易犯的小错误
Oct 21 Python
python list等分并从等分的子集中随机选取一个数
Nov 16 Python
Scrapy-Redis之RedisSpider与RedisCrawlSpider详解
Nov 18 Python
python实现登录与注册系统
Nov 30 Python
OpenCV-Python直方图均衡化实现图像去雾
Jun 07 Python
使用Numpy对特征中的异常值进行替换及条件替换方式
Jun 08 #Python
Python替换NumPy数组中大于某个值的所有元素实例
Jun 08 #Python
python如何编写win程序
Jun 08 #Python
如何写python的配置文件
Jun 07 #Python
python dict乱码如何解决
Jun 07 #Python
python中adb有什么功能
Jun 07 #Python
python如何保存文本文件
Jun 07 #Python
You might like
如何用php获取文件名后缀
2013/06/09 PHP
PHP Switch 语句之学习笔记
2013/09/21 PHP
一个显示效果非常不错的PHP错误、异常处理类
2014/03/21 PHP
PHP使用GIFEncoder类生成的GIF动态图片验证码
2014/07/01 PHP
php生成4位数字验证码的实现代码
2015/11/23 PHP
php中字符串和整数比较的操作方法
2019/06/06 PHP
JavaScript对象模型-执行模型
2008/04/28 Javascript
IE6浏览器下resize事件被执行了多次解决方法
2012/12/11 Javascript
JavaScript操作XML文件之XML读取方法
2015/06/09 Javascript
浅谈Vue的基本应用
2016/12/27 Javascript
jQuery解析返回的xml和json方法详解
2017/01/05 Javascript
基于vue-upload-component封装一个图片上传组件的示例
2018/10/16 Javascript
vscode配置vue下的es6规范自动格式化详解
2019/03/20 Javascript
vue实现输入框自动跳转功能
2020/05/20 Javascript
基于vue项目设置resolves.alias: '@'路径并适配webstorm
2020/12/02 Vue.js
python写的一个squid访问日志分析的小程序
2014/09/17 Python
python中set常用操作汇总
2016/06/30 Python
使用apidoc管理RESTful风格Flask项目接口文档方法
2018/02/07 Python
django主动抛出403异常的方法详解
2019/01/04 Python
详解python实现交叉验证法与留出法
2019/07/11 Python
Python如何在DataFrame增加数值
2020/02/14 Python
Python unittest工作原理和使用过程解析
2020/02/24 Python
python 模拟登录B站的示例代码
2020/12/15 Python
Jacadi Paris美国官方网站:法国童装品牌
2017/10/15 全球购物
一套Java笔试题
2016/08/20 面试题
光声世纪笔试题目
2012/08/25 面试题
法学个人求职信范文
2014/01/27 职场文书
餐饮收银员岗位职责
2014/02/07 职场文书
理工类毕业自我鉴定
2014/02/20 职场文书
社区健康教育实施方案
2014/03/18 职场文书
投标承诺函范文
2015/01/21 职场文书
辞职申请书范本
2019/05/20 职场文书
四年级作文之植物
2019/09/20 职场文书
Python matplotlib多个子图绘制整合
2022/04/13 Python
golang操作redis的客户端包有多个比如redigo、go-redis
2022/04/14 Golang
使用MybatisPlus打印sql语句
2022/04/22 SQL Server