箱型图检测异常值

import pandas as pd
import matplotlib.pyplot as plt
data = pd.read_excel('pdata.xls', encoding='utf-8', index_col=u'num')
#SyntaxError: invalid character in identifier代码中有中文字符
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()# 'flies'即为异常值的标签
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()#展示箱型图

 

 

你可能感兴趣的:(数据分析)