在做项目时遇到了一个错误:

#过滤出正常的工作经验值数据集合不正常的工作经验布尔值

dfExp=data.query('Experience>0')

negExp=data.Experience<0

mylist=data.loc[negExp]['ID'].tolist()

#对每一个工作经验为负的样本,用同年龄和教育程度的工作经验均值代替

for id in mylist:

age=data.query('ID==@id').Age.tolist()[0]

education=data.query('ID==@id').Education.tolist()[0]

df_filtered=dfExp.query('Age==@age and Education==@education')

exp=df_filtered['Experience'].median()

if exp is not np.nan:

exp=data.Experience.median()

data.loc[data.query('ID==@id').index,'Experience']=exp

print(data.Experience.describe())

sns.distplot(data.Experience)

上面这一段代码,目的是通过for循环把数据下Experience(工作经验)列中的异常值,即负值进行清洗,因为工作经验与年龄和受教育程度是高度相关的,所以把工作经验为负的值转化为相同年龄和受教育程度的中位数值。

即如果工作经验为-1,而年龄为30、受教育程度毕业生,那就把年龄为30且教育程度为毕业生的这些人的中位数,比如5,赋值给此条数据,用5去代替-1。

可是运行完这个数据后却报错了cannot convert float NaN to integer

大意:不能把浮点类型的空值NaN转换成整数。

百思不得其解

首先我比较奇怪难道数据一开始存在NaN么?

data[data['Experience'].isnull()]

于是输入了上面代码,发现对工作经验列进行处理之前数据中是没有空值存在的,显然这些空值是在数据进行处理后产生的。

于是对于数据代码我也反复确认了,发现其中并没有什么有问题的地方。

于是问了度娘:

原来是安装的matplotlib有bug存在,在Annoconda中更显一下就好了。

pip install --upgrade matplotlib_venn

安装成功后重启notebook,果然不再报错!

python为什么会出现nan_NaN为何会凭空产生?相关推荐

  1. python装饰器带参数函数二阶导数公式_SICP Python 描述 1.6 高阶函数

    1.6 高阶函数 我们已经看到,函数实际上是描述复合操作的抽象,这些操作不依赖于它们的参数值.在square中, >>> def square(x): return x * x 我们 ...

  2. python装饰器带参数函数二阶导数公式_【计算机程序的构造和解释】使用函数构建抽象——5. 高阶函数...

    学Python,用RPA 艺赛旗RPA2020.1版本 正在免费下载使用中,欢迎下载使用艺赛旗-RPA机器人免费下载|提供流程自动化解决方案​www.i-search.com.cn 我们已经看到,函数 ...

  3. Python 函数的艺术:高阶函数

    我们已经看到,函数实际上是描述复合操作的抽象,这些操作不依赖于它们的参数值.在square中, >>> def square(x):return x * x 我们不会谈论特定数值的平 ...

  4. python 帮助文档、自我解释

    现在让我们以交互方式使用 Python 来开始研究.当我们从命令行启动 Python 时,就进入了 Python shell,在这里可以输入 Python 代码,而且立刻会从 Python 解释器获得 ...

  5. Python 之父为什么嫌弃 lambda 匿名函数?

    点击上方"小白学视觉",选择加"星标"或"置顶" 重磅干货,第一时间送达 本文转自:AI算法与图像处理 Python 支持 lambda 匿 ...

  6. Python设计模式面向对象编程

    前言 本篇文章是基于极客时间王争的<设计模式之美>做的总结和自己的理解.   说到面向对象编程,作为一个合格的Pythoner,可以说信手拈来.毕竟在Python里"万物都是对象 ...

  7. python常见错误集合

    使用python会出现各种各样的错误,LZ专门设立了一个博客,在今后使用的过程中,遇到不同的问题都会把它整理到这个博客下面. 1.ValueError: 'Conv2d_1a_3×3' is not ...

  8. len(x) 击败 x.len(),从内置函数看 Python 的设计思想

    内置函数是 Python 的一大特色,用极简的语法实现很多常用的操作. 它们预先定义在内置命名空间中,开箱即用,所见即所得.Python 被公认是一种新手友好型的语言,这种说法能够成立,内置函数在其中 ...

  9. python中哪里用到缩进_Python编程常见十大错误

    使用python会出现各种各样的错误,以下是Python常见的错误以及解决方法. ValueError: 'Conv2d_1a_3×3' is not a valid scope name 其实这就是 ...

最新文章

  1. Android内存管理之道
  2. 微服务中的网关到底是个什么鬼?
  3. 从设置、加载、启动看Xilinx FPGA配置流程
  4. 第十、十一周项目二-存储班长信息的学生类
  5. python爬虫Scrapy框架之增量式爬虫
  6. 发点牢骚,关于微软,关于WPF/E
  7. linux进程调度时间片算法,进程调度算法–时间片轮转调度算法
  8. 【算法工程师】深度学习面试问题总结
  9. 东芝2303am维护清零_东芝复印机维修代码大全
  10. php 匹配中英文分号,PHP正则匹配中英文、数字及下划线的方法【用户名验证】 原创...
  11. 智能名片小程序开发文档概要
  12. SLG游戏中绘制六边形网格地形
  13. 如何判断欠拟合、适度拟合、过拟合
  14. HTML5制作一个笑脸
  15. 将用户需求转成产品需求
  16. win10 powershell无法激活conda v4.9环境
  17. 你的设备遇到问题,需要重启;我们只收集某些错误信息,然后为你重新启动。
  18. 拼多多校招算法题迷宫寻路
  19. 一门编程语言的通用知识点
  20. 云平台运行python_如何免费云端运行Python深度学习框架?

热门文章

  1. oracle获取系统时间上一个月
  2. 《BitUp》:像素风格游戏及地图编辑器的开发历程
  3. c语言scanf需要lf吗,c语言scanf(%d), scanf(%C), scanf(%lf)意思一样么
  4. 在PCB设计中应考虑到哪些因素?
  5. 你会用QQ吗?33个QQ小技巧你知道几个?
  6. web端,qq互联以及微信登录接入流程(内嵌页面)总结
  7. C#QQ找茬助手(一)开始作弊!
  8. matlab中 w 和 r,如何使用MATLAB 编辑公式 w^2=λ/π(根号下L(R-L)) L 是个变量 取值1到100 能不能画出一条曲线...
  9. JAVA蘑菇西餐,今天为大家推荐一道非常好吃的西餐,蘑菇鸡扒
  10. chrome扩展开发(2)- manifest.json文件简述