Python數據清洗之利用pandas篩選數據詳解
利用pandas篩選數據
在Pandas中,最常用的數據結構是Series和DataFrame。
Series是一維的數組-like對象,用于存儲任意類型的數據。
DataFrame是二維的表格型數據結構,可以存儲多種類型的數據,并且可以進行靈活的數據操作和分析。
直接篩選
比較運算符(==、<、>、>=、<=、!=)邏輯運算符 &(與)、|(或)、~(非),使用比較運算符時,請將每個條件括在括號內。
運算符的優(yōu)先級是NOT(?),AND(&),OR(|)。
讀取數據
import os import pandas as pd import numpy as np #讀取文件 def read_file(filepath): os.chdir(os.path.dirname(filepath)) return pd.read_csv(os.path.basename(filepath),encoding='utf-8') file_pos="C:\\Users\\周曉婷\\Desktop\\train_data_original.csv" data_pos=read_file(file_pos)
查看數據類型
data_pos.dtypes
篩選出frand_flag為0的數據
data_pos[data_pos['frand_flag']==0] ##用比較運算符‘=='直接篩選
篩選出frand_flag不為1的數據
data_pos[data_pos['frand_flag']!=1] data_pos[~(data_pos['frand_flag']==1)]
篩選cdr_duration>=15的數據
data_pos[data_pos['cdr_duration']>=15] ##用比較運算符“>=”直接篩選
篩選cdr_duration<15的數據
data_pos[data_pos['cdr_duration']<15]
篩選cdr_duration<=15且frand_flag=0的數據
data_pos[(data_pos['cdr_duration']<=15)&(data_pos['frand_flag']==0)]
篩選cdr_duration<=15或cdr_duration>60的數據
data_pos[(data_pos['cdr_duration']<=15)|(data_pos['cdr_duration']>60)]
函數篩選
比較函數(eq, ne, le, lt, ge, gt)
篩選出frand_flag為0的數據
data_pos[data_pos['frand_flag'].eq(0)]
篩選出frand_flag不為1的數據
data_pos[data_pos['frand_flag'].ne(1)]
篩選cdr_duration>=15的數據
data_pos[data_pos['cdr_duration'].ge(15)]
篩選cdr_duration<=15的數據
data_pos[data_pos['cdr_duration'].le(15)]
篩選cdr_duration<=15且frand_flag=0的數據
data_pos[(data_pos['cdr_duration'].le(15))&(data_pos['frand_flag'].eq(0))]
范圍運算 between(left,right)
篩選cdr_duration>=15或cdr_duration<=60的數據
data_pos[data_pos['cdr_duration'].between(15,60)]
篩選start_date>=20220701且start_date<=20221031的數據
data_pos[data_pos['start_date'].between(20220701,20221031)]
字符篩選 Series.str.contains(pattern或字符串,na=False)
測試pattern或regex是否包含在Series或Index的字符串中。
Series列要為字符數據類型。
最終返回:布爾值的系列或索引。
布爾值的Series或Index,指示給定模式是否包含在Series或Index的每個元素的字符串中。
函數語法:
Series.str.contains(pat,case = True,flags = 0,na = nan,regex = True)
參數說明如下:
參數 | 描述 |
pat | str類型。字符序列或正則表達式。 |
case | bool,默認為True。如果為True,區(qū)分大小寫。 |
flags | int,默認為0(無標志)。標志傳遞到re模塊,例如re.IGNORECASE。 |
na | 默認NaN,填寫缺失值的值。 |
regex | bool,默認為True。如果為True,則假定pat是正則表達式。如果為False,則將pat視為文字字符串。所以針對特殊符號,默認情況下我們必須使用轉義符,或者設置 regex=False。 |
篩選billing_nbr為移動號碼,移動號碼用正則表達式
#該列轉換為字符數據類型(2種方法) data_pos['billing_nbr']=data_pos['billing_nbr'].apply(str) data_pos['billing_nbr']=data_pos['billing_nbr'].values.astype('str') data_pos=data_pos[data_pos['billing_nbr'].str.contains('^1[35678]\d{9}$')] print(data_pos.shape)
模糊查詢,篩選某列中包含某個字符,比如“篩選start_date為202207的數據”
data_pos['start_date']=data_pos['start_date'].apply(str) data_pos=data_pos[data_pos['start_date'].str.contains('202207')] print(data_pos.shape)
篩選channel_type_desc為實體渠道的數據,na=False的意思就是,遇到非字符串的情況,直接忽略。你也可以寫na=True,意思就是遇到非字符串的情況,計為篩選有效。如果遇到非字符串沒有標明na參數會報錯。
data_pos_1=data_pos_1[data_pos_1['channel_type_desc'].str.contains('實體渠道',na=False)]
apply()函數
篩選出frand_flag為0的數據
data_pos[data_pos['frand_flag'].apply(lambda x:x==0)]
截取billing_nbr前7位數
data_pos['billing_nbr']=data_pos['billing_nbr'].apply(str) data_pos['billing_nbr_pre7']=data_pos['billing_nbr'].apply(lambda x:x[0:8]) data_pos['billing_nbr_pre7']=data_pos['billing_nbr'].map(lambda x:x[0:8])
篩選billing_nbr為移動號碼,移動號碼用正則表達式
import re def func(x): if re.search('^1[35678]\d{9}$',x): return(True) else: return(False) data_pos[data_pos['billing_nbr'].apply(func)]
篩選某一列并替換其他字符:篩選channel_type_desc列,將”含有實體渠道的“全部替換”實體渠道”,將“含有電子渠道的”全部替換成“電子渠道”,將“含有直銷渠道的”全部替換成“直銷渠道”,其他替換為未知。
未修改前,數據詳情:
import re def func(data): if re.match(r'[\u4e00-\u9fa5]*實體渠道*[\u4e00-\u9fa5]',str(data)): return "實體渠道" elif re.match(r'[\u4e00-\u9fa5]*電子渠道*[\u4e00-\u9fa5]',str(data)): return "電子渠道" elif re.match(r'[\u4e00-\u9fa5]*直銷渠道*[\u4e00-\u9fa5]',str(data)): return "直銷渠道" else: return "未識別" data_pos_1['channel_type_desc_1']=data_pos_1.channel_type_desc.apply(func)
import re def func(x): if re.search(r'[\u4e00-\u9fa5]*實體渠道*[\u4e00-\u9fa5]',str(x)): return "實體渠道" elif re.search(r'[\u4e00-\u9fa5]*電子渠道*[\u4e00-\u9fa5]',str(x)): return "電子渠道" elif re.search(r'[\u4e00-\u9fa5]*直銷渠道*[\u4e00-\u9fa5]',str(x)): return "直銷渠道" else: return "未識別" data_pos_1['channel_type_desc_1']=data_pos_1.channel_type_desc.apply(func)
數據替代后,數據詳情:
isin()函數,支持多值篩選,用列表表示
篩選出frand_flag為0的數據
data_pos[data_pos['frand_flag'].isin([0])]
篩選出called_nbr包含10086、10010、10016、114的數據
data_pos[data_pos['called_nbr'].isin([10086,10010,10016,114])]
~isin()
篩選called_nbr不包含10086、10010、10016、114的數據
data_pos[~data_pos['called_nbr'].isin([10086,10010,10016,114])]
到此這篇關于Python數據清洗之利用pandas篩選數據詳解的文章就介紹到這了,更多相關pandas篩選數據內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
python實現在sqlite動態(tài)創(chuàng)建表的方法
這篇文章主要介紹了python實現在sqlite動態(tài)創(chuàng)建表的方法,涉及Python操作SQLite數據庫創(chuàng)建數據表的技巧,具有一定參考借鑒價值,需要的朋友可以參考下2015-05-05詳解python websocket獲取實時數據的幾種常見鏈接方式
這篇文章主要介紹了詳解python websocket獲取實時數據的幾種常見鏈接方式,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2019-07-07