python使用箱型圖剔除異常值的實(shí)現(xiàn)方法
箱型圖
將一組數(shù)據(jù)從大到小排列,分別計(jì)算出,
- 上四分位數(shù)??3: 75%分位點(diǎn)所對(duì)應(yīng)的值
- 中位數(shù)??2: 50%分位點(diǎn)對(duì)應(yīng)的值
- 下四分位數(shù)??1: 25%分位點(diǎn)所對(duì)應(yīng)的值
- 上邊緣(須): Q3+1.5(Q3-Q1)
- 下邊緣(須): Q1-1.5(Q3-Q1)
數(shù)據(jù)??的合理范圍為:
??1 − 1.5(??3 − ??1) ≤ ?? ≤ ??3 + 1.5(??3 − ??1)
和使用3σ準(zhǔn)則剔除異常值相比,箱線圖不需要數(shù)據(jù)服從正態(tài)分布,能真實(shí)直觀的表現(xiàn)數(shù)據(jù)形狀;箱線圖以四分位數(shù)和四分位距作為判斷異常值的標(biāo)準(zhǔn),四分位數(shù)具有一定的耐抗性,多達(dá) 25%的數(shù)據(jù)可以變得任意遠(yuǎn)而不會(huì)很大地?cái)_動(dòng)四分位數(shù),使得異常值無(wú)法對(duì)數(shù)據(jù)形狀造成巨大影響,因此箱形圖識(shí)別異常值的結(jié)果比較客觀。
pandas.DataFrame.quantile
對(duì)于dataframe形式的數(shù)據(jù),可以直接調(diào)用DataFrame.quantile(),以快速計(jì)算箱型圖的分位點(diǎn)。
DataFrame.quantile(q=0.5, axis=0, numeric_only=True, interpolation='linear')
參數(shù):
- q:float or array-like, default 0.5 (50% quantile),0 ≤ q ≤ 1之間的值,即要計(jì)算的分位數(shù);
- axis:{0, 1, ‘index’, ‘columns’}, default 0,對(duì)于行,等于0或“索引”,對(duì)于列,等于1或“列”;
- numeric_only:bool, default True,如果為False,則還將計(jì)算日期時(shí)間和時(shí)間增量數(shù)據(jù)的分位數(shù);
- interpolation:{‘linear’, ‘lower’, ‘higher’, ‘midpoint’, ‘nearest’},當(dāng)所需分位數(shù)位于兩個(gè)數(shù)據(jù)點(diǎn)i和j之間時(shí),此可選參數(shù)指定要使用的插值方法。
返回:(Series or DataFrame)
- 如果q是數(shù)組,則將返回DataFrame,其中index為q,列為self的列,值為分位數(shù)。
- 如果q為float,則index是self的列,值為分位數(shù)
示例:
import pandas as pd import numpy as np # 生成數(shù)據(jù) d = pd.DataFrame({"SO2":[-1000, 5, 5, 10, 9, 12, 11, 100], "NO2":[12, 52, 14, 10, 10, 23, 15, 9], "CO2":[15, 23, 0, 24, 25, 7, 4, 715], "O3":[17, 23, 33, 10000, 11, 47, 5, 22] })
q 為 float:
q 為 數(shù)組:
代碼實(shí)現(xiàn)
# 箱型圖判斷異常點(diǎn) def box_outlier(data): df = data.copy(deep=True) out_index = [] for col in df.columns: # 對(duì)每一列分別用箱型圖進(jìn)行判斷 Q1 = df[col].quantile(q=0.25) # 下四分位 Q3 = df[col].quantile(q=0.75) # 上四分位 low_whisker = Q1 - 1.5 * (Q3 - Q1) # 下邊緣 up_whisker = Q3 + 1.5 * (Q3 - Q1) # 上邊緣 # 尋找異常點(diǎn),獲得異常點(diǎn)索引值,刪除索引值所在行數(shù)據(jù) rule = (df[col] > up_whisker) | (df[col] < low_whisker) out = df[col].index[rule] out_index += out.tolist() df.drop(out_index, inplace=True) return df
使用前文創(chuàng)建的數(shù)據(jù)
box_outlier(d)
參考
【PYTHON 機(jī)器學(xué)習(xí)】正態(tài)分布檢驗(yàn)以及異常值處理3Σ原則
總結(jié)
到此這篇關(guān)于python使用箱型圖剔除異常值的文章就介紹到這了,更多相關(guān)python箱型圖剔除異常值內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Pytorch平均池化nn.AvgPool2d()使用方法實(shí)例
平均池化層,又叫平均匯聚層,下面這篇文章主要給大家介紹了關(guān)于Pytorch平均池化nn.AvgPool2d()使用方法的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-02-02Python3.4學(xué)習(xí)筆記之列表、數(shù)組操作示例
這篇文章主要介紹了Python3.4列表、數(shù)組操作,結(jié)合實(shí)例形式分析了Python3.4列表的創(chuàng)建、元素追加、刪除、排序等相關(guān)操作技巧,需要的朋友可以參考下2019-03-03升級(jí)anaconda中python到3.10版本的簡(jiǎn)單步驟
anaconda是一個(gè)非常好用的python發(fā)行版本,其中包含了大部分常用的庫(kù),下面這篇文章主要給大家介紹了關(guān)于升級(jí)anaconda中python到3.10版本的簡(jiǎn)單步驟,需要的朋友可以參考下2024-03-03利用Python實(shí)現(xiàn)在同一網(wǎng)絡(luò)中的本地文件共享方法
今天小編就為大家分享一篇利用Python實(shí)現(xiàn)在同一網(wǎng)絡(luò)中的本地文件共享方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-06-06詳解pandas DataFrame的查詢(xún)方法(loc,iloc,at,iat,ix的用法和區(qū)別)
這篇文章主要介紹了詳解pandas DataFrame的查詢(xún)方法(loc,iloc,at,iat,ix的用法和區(qū)別),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-08-08Python的bit_length函數(shù)來(lái)二進(jìn)制的位數(shù)方法
今天小編就為大家分享一篇Python的bit_length函數(shù)來(lái)二進(jìn)制的位數(shù)方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-08-08python:解析requests返回的response(json格式)說(shuō)明
這篇文章主要介紹了python:解析requests返回的response(json格式)說(shuō)明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-04-04python wxpython 實(shí)現(xiàn)界面跳轉(zhuǎn)功能
wxpython沒(méi)提供界面跳轉(zhuǎn)的方式,所以就需要借助threading模塊,本文給大家分享python wxpython 實(shí)現(xiàn)界面跳轉(zhuǎn)功能,感興趣的朋友跟隨小編一起看看吧2019-12-12