博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
数据分析—缺失值处理
阅读量:5939 次
发布时间:2019-06-19

本文共 5194 字,大约阅读时间需要 17 分钟。

我们获取到的数据(尤其是数据量比较大时),很有可能会出现数据缺失、数据异常等问题,数据处理是数据分析里十分重要且必须的一个环节,为了在做数据分析时尽可能减少异常的出现,以及得出更精准的分析结论,因此在做数据分析之前,数据处理显得尤其必要

阅读条件:熟悉pandas基本操作
使用工具:Python

使用平台:jupyter notebook

缺失值处理

缺失值判断

python主要读取的是csv或者excel数据,excel中单元格为空时,pandas读取显示的是NaN,即为缺失值

判断缺失值数据方法:isnull,notnull

  • isnull:True表示缺失,False表示非缺失
  • notnull:True表示非缺失,False表示缺失

首先导入python数据分析必选工具包

import numpy as npimport pandas as pd__author__='莫叹'复制代码

生成一个表格型的二维数组df

#生成一个表格型的二维数组df=pd.DataFrame({
'a':[34,6,20,np.nan,56], 'b':['juejin','number','one','good',np.nan]})复制代码

输出如下:

判断数据中是否存在缺失值以及非缺失值数据筛选:

#判断二维数组df是否缺失print(df.notnull(),'\n')#通过索引判断a列是否缺失print(df['a'].notnull(),'\n')#筛选a列不存在缺失值数组print(df[df['a'].notnull()])复制代码

输出如下:

a      b0   True   True1   True   True2   True   True3  False   True4   True  False 0     True1     True2     True3    False4     TrueName: a, dtype: bool       a       b0  34.0  juejin1   6.0  number2  20.0     one4  56.0     NaN复制代码

缺失值删除

通过上面的notnull布尔序列值筛选也是缺失值删除的一种方法

缺失值的删除需要按照具体数据情况和业务情况来处理,有时候需要删除全部缺失数据,有时候需要删除部分缺失数据,有时候只是需要删除指定缺失数据。

删除缺失值的方法:dropna(axis)

  • 默认参数axis = 0,为删除行数据,当参数axis = 1删除列数据(但是一般不会选择axis=1,如果为1,则直接删除了一整个变量数据)
  • 传入thresh=n时保留至少有n个非NaN数据的行

#生成一个表格型二维数组df2=pd.DataFrame([[1,2,3],['juejin',np.nan,np.nan],['a','b',np.nan],[np.nan,np.nan,np.nan],['d','j','h']],                 columns=list('ABC'))print(df2,'\n')#删除所有存在缺失值的行print(df2.dropna(),'\n')#删除部分存在缺失值的行,保留至少有n个非NaN数据的行(比如保留至少有一个非NaN数据的行)print(df2.dropna(thresh=1),'\n')#删除某一列存在缺失值的行(删除A列里存在缺失值的所有的行,和上面的布尔值序列筛选相同)print(df2[df2['A'].notnull()])复制代码

输出如下:

A    B    C0       1    2    31  juejin  NaN  NaN2       a    b  NaN3     NaN  NaN  NaN4       d    j    h    A  B  C0  1  2  34  d  j  h         A    B    C0       1    2    31  juejin  NaN  NaN2       a    b  NaN4       d    j    h         A    B    C0       1    2    31  juejin  NaN  NaN2       a    b  NaN4       d    j    h复制代码

缺失值填充/替换

填充方法:fillna(value=None, method=None, axis=None, inplace=False, limit=None, downcast=None, **kwargs)

  • value参数:填充值
  • method参数: pad / ffill → 用之前的数据填充,backfill / bfill → 用之后的数据填充

替换方法:replace(to_replace=None, value=None, inplace=False, limit=None, regex=False, method='pad', axis=None)

  • to_replacec参数:被替换的值
  • value参数:替换值

使用举例如下:

import copydf3=pd.DataFrame([[1,2,3],['juejin',np.nan,np.nan],['a','b',np.nan],['k',np.nan,np.nan],['d','j','h']],                 columns=list('ABC'))df4=copy.deepcopy(df3)print(df3,'\n')#缺失值全部用 0 填充print(df3.fillna(0),'\n')#method=‘pad’,使B列每一个缺失值用缺失值的前一个值填充df3['B'].fillna(method='pad',inplace=True)print(df3,'\n')#用replace替换print(df4,'\n')df4.replace(np.nan,'juejin',inplace = True)print('将缺失值替换为juejin\n',df4)复制代码

A    B    C0       1    2    31  juejin  NaN  NaN2       a    b  NaN3       k  NaN  NaN4       d    j    h         A  B  C0       1  2  31  juejin  0  02       a  b  03       k  0  04       d  j  h         A  B    C0       1  2    31  juejin  2  NaN2       a  b  NaN3       k  b  NaN4       d  j    h         A    B    C0       1    2    31  juejin  NaN  NaN2       a    b  NaN3       k  NaN  NaN4       d    j    h将缺失值替换为juejin         A       B       C0       1       2       31  juejin  juejin  juejin2       a       b  juejin3       k  juejin  juejin4       d       j       h复制代码

缺失值插值

上面讲到缺失值的填充,但是在实际的数据处理过程中,对于缺失值的处理不是随便找个数据全部填充,而是有针对性的对每个局部缺失值进行插值填充。

这里选择几种常用的具有代表性的缺失值插值方法:

  • 中位数/众数/平均值插值
  • 临近值插值
  • 拉格朗日值插值
中位数/众数/平均值插补

#生成一个一维数组s1=pd.Series([6,4,2,5,4,3,3,7,np.nan,3,9,np.nan,1])print(s1,'\n')med=s1.median()#中位数mod=s1.mode()#众数avg=s1.mean() #平均值print('中位数,众数,平均数分别为:%.2f,%.2f,%.2f'%(med,mod,avg))#以平均值为例s1.fillna(avg)复制代码

0     6.01     4.02     2.03     5.04     4.05     3.06     3.07     7.08     NaN9     3.010    9.011    NaN12    1.0dtype: float64 中位数,众数,平均数分别为:4.00,3.00,4.270     6.0000001     4.0000002     2.0000003     5.0000004     4.0000005     3.0000006     3.0000007     7.0000008     4.2727279     3.00000010    9.00000011    4.27272712    1.000000dtype: float64复制代码

临近值插补

这点其实在上面缺失值填充里提到了,主要是method这个参数,可选择缺失值位置前一个或者和一个位置上数据填充相同的数据即可,可参考df3

fillna(value=None, method=None, axis=None, inplace=False, limit=None, downcast=None, **kwargs)

method参数: pad / ffill → 用之前的数据填充,backfill / bfill → 用之后的数据填充

拉格朗日插值法

许多实际问题中都用函数来表示某种内在联系或规律,而不少函数都只能通过实验和观测来了解。如对实践中的某个物理量进行观测,在若干个不同的地方得到相应的观测值,拉格朗日插值法可以找到一个,其恰好在各个观测的点取到观测到的值。这样的多项式称为。数学上来说,拉格朗日插值法可以给出一个恰好穿过二维平面上若干个已知点的多项式函数。

限于篇幅,这里就粗糙的讲解一下拉格朗日插值法的计算过程

根据数学知识,对于平面上已知的n个点,可以找到一个n-1次多项式:

当我们知道前面的n-1个坐标点(x1,y1),(x2,y2)......(xn-1,yn-1)的值时,代入上面公式可以得到如下的一个多元方程

通过这个多元方程,我们就可以计算出参数a0,a1,.....an-1的值,知道了这个多元方程的各个参数,也就是知道了一个y与x之间的函数方程,传入x值,就可以计算出对应的缺失的y值(一个近似值),形如上面计算值得过程叫做拉格朗日插值法。

在python里,有一个十分方便计算拉格朗日插值的工具库,具体使用和实现过程直接在下面代码里举例实现

我们随意选择一组数据(3,6)、(7,9)、(8,5)、(9,8)利用拉格朗日插值法算出过这些点的函数方程,然后输入我们需要插值的x的值,自然可以得到y值。

#导入拉格朗日插值法计算和作图包from scipy.interpolate import lagrangeimport matplotlib.pyplot as plt% matplotlib inline#任意创建一个有缺失值的二维数组s2=pd.DataFrame({
'x':[3,7,12,8,9],'y':[6,9,np.nan,5,8]})#x值x=[3,7,8,9]#y值y=[6,9,5,8]#生成这几个点的散点图plt.scatter(x,y)#求出函数方程print(lagrange(x,y))#选择一个x=12,计算插入值print('插值12为%.2f' % lagrange(x,y)(12))复制代码

生成的函数(上面的数字3和2表示x³和x²)、对应的缺失值插值、散点图如下:

3        20.7417 x - 14.3 x + 85.16 x - 140.8插值12为103.50复制代码

所以x=12时,对应的缺失值可以用103.50来插入代替

转载于:https://juejin.im/post/5d060839e51d455a694f951e

你可能感兴趣的文章
angularjs指令(二)
查看>>
(原創) 如何建立一个thread? (OS) (Linux) (C/C++) (C)
查看>>
<气场>读书笔记
查看>>
领域驱动设计,构建简单的新闻系统,20分钟够吗?
查看>>
web安全问题分析与防御总结
查看>>
React 组件通信之 React context
查看>>
ZooKeeper 可视化监控 zkui
查看>>
Linux下通过配置Crontab实现进程守护
查看>>
ios 打包上传Appstore 时报的错误 90101 90149
查看>>
Oracle推出轻量级Java微服务框架Helidon
查看>>
密码概述
查看>>
autoconf,automake,libtool
查看>>
jQuery的技巧01
查看>>
基于泛型实现的ibatis通用分页查询
查看>>
gopacket 使用
查看>>
AlertDialog对话框
查看>>
我的友情链接
查看>>
办公室几台电脑怎么连一台打印机的具体步骤
查看>>
linux安全---cacti+ntop监控
查看>>
鸟哥的linux私房菜-shell简单学习-1
查看>>