Python箱型图处理离群点

Python箱型图处理离群点

首先我们简单地区分一下离群点(outlier)以及异常值(anomaly):


  • 离群点:
    Python箱型图处理离群点_第1张图片
    Python箱型图处理离群点_第2张图片
  • 异常值:

个人觉着异常值和离群点是两个不同的概念,当然大家在数据预处理时对于这两个概念不做细致的区分,不如:姚明站在我们中间的时候,我觉着我们只能说他是一个离群点,我们能说他异常吗?异常的假设是姚明得了巨人症,可是他不是。


箱型图

Python箱型图处理离群点_第3张图片

五数概念(five-number summary)由中位数( Q2 )、四分位数 Q1 Q3 、最大(Maximum)和最小(Minimum)观测值组成,按次序Minimum, Q1 Q2 Q3 ,Maximum。可疑的离群点通常是落在 Q3 之上或 Q1 之下至少 1.5IQR

代码块

餐饮销售数据离群点检测代码:

#-*- coding: utf-8 -*-
import pandas as pd

catering_sale = '../data/catering_sale.xls' #餐饮数据
data = pd.read_excel(catering_sale, index_col = u'日期') #读取数据,指定“日期”列为索引列

import matplotlib.pyplot as plt #导入图像库
plt.rcParams['font.sans-serif'] = ['SimHei'] #用来正常显示中文标签
plt.rcParams['axes.unicode_minus'] = False #用来正常显示负号

plt.figure() #建立图像
p = data.boxplot(return_type='dict') #画箱线图,直接使用DataFrame的方法
x = p['fliers'][0].get_xdata() # 'fliers'即为离群点的标签
y = p['fliers'][0].get_ydata()
y.sort() #从小到大排序,该方法直接改变原对象

#用annotate添加注释
#其中有些相近的点,注解会出现重叠,难以看清,需要一些技巧来控制。
#以下参数都是经过调试的,需要具体问题具体调试。
for i in range(len(x)): 
  if i > 0:
    plt.annotate(y[i], xy = (x[i],y[i]), xytext=(x[i]+0.05 -0.8/(y[i]-y[i-1]),y[i]))
  else:
    plt.annotate(y[i], xy = (x[i],y[i]), xytext=(x[i]+0.08,y[i]))

plt.show() #展示箱线图

运行结果:
Python箱型图处理离群点_第4张图片

你可能感兴趣的:(python数据分析与挖掘实战)