使用Pandas實(shí)現(xiàn)清洗客戶編碼異常數(shù)據(jù)
前言
在不同行業(yè)中,我們經(jīng)常會(huì)遇到一個(gè)麻煩的問(wèn)題:數(shù)據(jù)清洗。尤其是當(dāng)我們需要處理客戶編碼異常數(shù)據(jù)時(shí),這個(gè)問(wèn)題變得尤為重要。想象一下,許多銀行都是以客戶為單位管理數(shù)據(jù)的,因此每個(gè)客戶都有一個(gè)獨(dú)特的編碼。在處理這些數(shù)據(jù)時(shí),我們常常會(huì)面臨以下問(wèn)題:
1.客戶編碼有一個(gè)為空,另一個(gè)不為空的情況。
2.客戶編碼存在多個(gè)不同的值。
3.客戶編碼為空。
針對(duì)這些令人頭疼的問(wèn)題,接下來(lái)我將詳細(xì)介紹如何使用pandas清洗客戶編碼異常數(shù)據(jù)。
創(chuàng)建一個(gè)新的數(shù)據(jù)集
首先我們要?jiǎng)?chuàng)建一個(gè)新的數(shù)據(jù)集,這個(gè)數(shù)據(jù)集的目的是用來(lái)對(duì)客戶的編碼進(jìn)行清洗。
import pandas as pd import numpy as np data = { '主鍵': [1, 2, 3, 4, 5, 6, 7, 8, 9, 10], 'MDG編碼': [np.nan, np.nan, 'A001', 'A002', np.nan, 'B001', 'B002', np.nan, 'C001', 'C002'], '客戶名稱': ['客戶1', '客戶1', '客戶1', '客戶2', '客戶2', '客戶3', '客戶3', '客戶4', '客戶4', '客戶4'], '證件號(hào)': ['111111', '111111', '111111', '222222', '222222', '333333', '333333', '444444', '444444', '444444'], '客戶類型': ['類型1', '類型1', '類型1', '類型2', '類型2', '類型3', '類型3', '類型4', '類型4', '類型4'] } yb = pd.DataFrame(data) yb
輸出
字符串空值轉(zhuǎn)換
pandas識(shí)別空字符串為非空值,所以我們需要將編碼為空的數(shù)據(jù)轉(zhuǎn)換為pandas能識(shí)別的NaN。
yb.MDG編碼.replace(to_replace=r'^\s*$', value=np.nan, regex=True, inplace=True) cf = yb[(yb.duplicated(['客戶名稱'], keep=False)) & (yb.客戶類型 != '類型1')] #只獲取有重復(fù)的客戶,減少需要處理的數(shù)據(jù)量 cf
輸出:同上
構(gòu)造分組函數(shù)、不同異常數(shù)據(jù)進(jìn)行分組
cf['count'] = np.nan cf.sort_values(by=['客戶名稱','MDG編碼'],inplace=True) def abc(x): df = set(x[x.notnull()]) if len(df)==1: if len(set(x))>1: return 2 else: return 1 elif len(df)>=2: return 3 cf['count'] = cf.groupby(['客戶名稱'])['MDG編碼'].transform(abc) cf
輸出
這段代碼的作用是在DataFrame(cf
)中創(chuàng)建一個(gè)新的列count
,然后根據(jù)'客戶名稱'
和'MDG編碼'
對(duì)DataFrame進(jìn)行排序。接下來(lái),定義了一個(gè)函數(shù)abc(x)
。
該函數(shù)首先將非空值存儲(chǔ)在一個(gè)集合df
中。如果集合df
中的元素個(gè)數(shù)為1,且字段x
中的不同值個(gè)數(shù)多于1個(gè),則返回2。如果集合df
中的元素個(gè)數(shù)為1,且字段x
中的不同值個(gè)數(shù)只有1個(gè),則返回1。如果集合df
中的元素個(gè)數(shù)大于等于2,則返回3。
最后,使用cf.groupby(['客戶名稱'])['MDG編碼'].transform(abc)
將函數(shù)abc
應(yīng)用到分組后的cf
DataFrame的'MDG編碼'
列中,并將結(jié)果賦值給cf
的'count'
列。
查詢正確的客戶編碼
#查詢mdg編碼正確的數(shù)據(jù) cf2 = cf[cf['count']==2] cf1 = cf2.loc[cf2.MDG編碼.notnull()] cf1 = cf1.drop_duplicates('客戶名稱') #mdg編碼不為空,且mdg編碼正確的數(shù)據(jù) cf1
輸出
獲取需要修改的異??蛻舻膇d
將mdg編碼為空的客戶 與 正確MDG編碼的客戶進(jìn)行匹配,獲取需要修改的客戶數(shù)據(jù)
cf3 = cf2[cf2.MDG編碼.isnull()].merge(cf1[['客戶名稱','MDG編碼']],how='left',on='客戶名稱') cf3 = cf3[['主鍵','MDG編碼_y','客戶名稱','證件號(hào)','客戶類型','MDG編碼_x']] cf3 #MDG編碼_y為正確編碼,主鍵為需要修改的id
輸出
上述情況是相同客戶有一個(gè)正確編碼和一個(gè)編碼為空的情況,對(duì)于相同客戶有兩個(gè)及兩個(gè)以上不同編碼的情況,使用下述方法查詢:
cf[cf['count']==3] #多個(gè)不相等mdg編碼
輸出
這類數(shù)據(jù)由于編碼有多個(gè)不相同,需要根據(jù)業(yè)務(wù)進(jìn)一步核實(shí)
總結(jié)
本文主要介紹了在 pandas中清洗客戶編碼異常數(shù)據(jù)的方法,使用這個(gè)方法我們可以快速的清洗客戶編碼異常數(shù)據(jù)。那么如果你想要對(duì)這個(gè)方法進(jìn)行優(yōu)化的話,我們還可以對(duì)數(shù)據(jù)進(jìn)行清洗。比如說(shuō)我們可以對(duì)原始數(shù)據(jù)進(jìn)行一次排序,然后在排序后的數(shù)據(jù)中尋找是否存在空值、重復(fù)值和重復(fù)編碼等問(wèn)題。
以上就是使用Pandas實(shí)現(xiàn)清洗客戶編碼異常數(shù)據(jù)的詳細(xì)內(nèi)容,更多關(guān)于Pandas清洗異常數(shù)據(jù)的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
使用Python實(shí)現(xiàn)VPN搭建的流程步驟
VPN(虛擬私人網(wǎng)絡(luò))是一種有效的解決方案,可以幫助我們?cè)诰W(wǎng)絡(luò)上匿名瀏覽,保護(hù)數(shù)據(jù)傳輸?shù)陌踩?雖然市面上有許多商業(yè)VPN服務(wù),但你也可以通過(guò)Python自己搭建一個(gè)簡(jiǎn)單的VPN,本文將介紹如何用Python建立自己的VPN,需要的朋友可以參考下2024-06-06keras讀取訓(xùn)練好的模型參數(shù)并把參數(shù)賦值給其它模型詳解
這篇文章主要介紹了keras讀取訓(xùn)練好的模型參數(shù)并把參數(shù)賦值給其它模型詳解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-06-06python 自動(dòng)監(jiān)控最新郵件并讀取的操作
這篇文章主要介紹了python 自動(dòng)監(jiān)控最新郵件并讀取的操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2021-03-03tensorflow如何將one_hot標(biāo)簽和數(shù)字(整數(shù))標(biāo)簽進(jìn)行相互轉(zhuǎn)化
這篇文章主要介紹了tensorflow如何將one_hot標(biāo)簽和數(shù)字(整數(shù))標(biāo)簽進(jìn)行相互轉(zhuǎn)化問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-06-06Python實(shí)現(xiàn)FTP文件定時(shí)自動(dòng)下載的步驟
這篇文章主要介紹了Python實(shí)現(xiàn)FTP文件定時(shí)自動(dòng)下載的示例,幫助大家更好的理解和使用python,感興趣的朋友可以了解下2020-12-12opencv3/C++實(shí)現(xiàn)視頻讀取、視頻寫(xiě)入
今天小編就為大家分享一篇opencv3/C++實(shí)現(xiàn)視頻讀取、視頻寫(xiě)入,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-12-12Python按條件刪除Excel表格數(shù)據(jù)的方法(示例詳解)
本文介紹基于Python語(yǔ)言,讀取Excel表格文件,基于我們給定的規(guī)則,對(duì)其中的數(shù)據(jù)加以篩選,將不在指定數(shù)據(jù)范圍內(nèi)的數(shù)據(jù)剔除,保留符合我們需要的數(shù)據(jù)的方法,感興趣的朋友跟隨小編一起看看吧2024-08-08