pandas數據篩選和csv操作的實現方法?很多新手對此不是很清楚,為了幫助大家解決這個難題,下面小編將為大家詳細講解,有這方面需求的人可以來學習下,希望你能有所收獲。
讓客戶滿意是我們工作的目標,不斷超越客戶的期望值來自于我們對這個行業的熱愛。我們立志把好的技術通過有效、簡單的方式提供給客戶,將通過不懈努力成為客戶在信息化領域值得信任、有價值的長期合作伙伴,公司提供的服務項目有:國際域名空間、虛擬空間、營銷軟件、網站建設、定海網站維護、網站推廣。1. 數據篩選
a b c 0 0 2 4 1 6 8 10 2 12 14 16 3 18 20 22 4 24 26 28 5 30 32 34 6 36 38 40 7 42 44 46 8 48 50 52 9 54 56 58
(1)單條件篩選
df[df['a']>30] # 如果想篩選a列的取值大于30的記錄,但是之顯示滿足條件的b,c列的值可以這么寫 df[['b','c']][df['a']>30] # 使用isin函數根據特定值篩選記錄。篩選a值等于30或者54的記錄 df[df.a.isin([30, 54])]
(2)多條件篩選
可以使用&(并)與| (或)操作符或者特定的函數實現多條件篩選
# 使用&篩選a列的取值大于30,b列的取值大于40的記錄 df[(df['a'] > 30) & (df['b'] > 40)]
(3)索引篩選
a. 切片操作
df[行索引,列索引]或df[[列名1,列名2]]
#使用切片操作選擇特定的行 df[1:4] #傳入列名選擇特定的列 df[['a','c']]
b. loc函數
當每列已有column name時,用 df [ ‘a' ] 就能選取出一整列數據。如果你知道column names 和index,且兩者都很好輸入,可以選擇 .loc同時進行行列選擇。
In [28]: df.loc[0,'c'] Out[28]: 4 In [29]: df.loc[1:4,['a','c']] Out[29]: a c 1 6 10 2 12 16 3 18 22 4 24 28 In [30]: df.loc[[1,3,5],['a','c']] Out[30]: a c 1 6 10 3 18 22 5 30 34
c. iloc函數
如果column name太長,輸入不方便,或者index是一列時間序列,更不好輸入,那就可以選擇 .iloc了,該方法接受列名的index,iloc 使得我們可以對column使用slice(切片)的方法對數據進行選取。這邊的 i 我覺得代表index,比較好記點。
In [35]: df.iloc[0,2] Out[35]: 4 In [34]: df.iloc[1:4,[0,2]] Out[34]: a c 1 6 10 2 12 16 3 18 22 In [36]: df.iloc[[1,3,5],[0,2]] Out[36]: a c 1 6 10 3 18 22 5 30 34 In [38]: df.iloc[[1,3,5],0:2] Out[38]: a b 1 6 8 3 18 20 5 30 32
d. ix函數
ix的功能更加強大,參數既可以是索引,也可以是名稱,相當于,loc和iloc的合體。需要注意的是在使用的時候需要統一,在行選擇時同時出現索引和名稱, 同樣在同行選擇時同時出現索引和名稱。
df.ix[1:3,['a','b']] Out[41]: a b 1 6 8 2 12 14 3 18 20 In [42]: df.ix[[1,3,5],['a','b']] Out[42]: a b 1 6 8 3 18 20 5 30 32 In [45]: df.ix[[1,3,5],[0,2]] Out[45]: a c 1 6 10 3 18 22 5 30 34
e. at函數
根據指定行index及列label,快速定位DataFrame的元素,選擇列時僅支持列名。
In [46]: df.at[3,'a'] Out[46]: 18
f. iat函數
與at的功能相同,只使用索引參數
In [49]: df.iat[3,0] Out[49]: 18
2. csv操作
csv文件內容
Supplier Name,Invoice Number,Part Number,Cost,Purchase Date Supplier X,001-1001,2341,$500.00 ,1/20/14 Supplier X,001-1001,2341,$500.00 ,1/20/14 Supplier X,001-1001,5467,$750.00 ,1/20/14 Supplier X,001-1001,5467,$750.00 ,1/20/14 Supplier Y,50-9501,7009,$250.00 ,1/30/14 Supplier Y,50-9501,7009,$250.00 ,1/30/14 Supplier Y,50-9505,6650,$125.00 ,2002/3/14 Supplier Y,50-9505,6650,$125.00 ,2002/3/14 Supplier Z,920-4803,3321,$615.00 ,2002/3/14 Supplier Z,920-4804,3321,$615.00 ,2002/10/14 Supplier Z,920-4805,3321,$615.00 ,2/17/14 Supplier Z,920-4806,3321,$615.00 ,2/24/14
(1)csv文件讀寫
關于read_csv函數中的參數說明參考博客:https://www.jb51.net/article/164445.htm
import pandas as pd # 讀寫csv文件 df = pd.read_csv("supplier_data.csv") df.to_csv("supplier_data_write.csv",index=None)
(2)篩選特定的行
#Supplier Nmae列中姓名包含'Z',或者Cost列中的值大于600 print(df[df["Supplier Name"].str.contains('Z')]) print(df[df['Cost'].str.strip('$').astype(float) > 600]) print(df.loc[(df["Supplier Name"].str.contains('Z'))|(df['Cost'].str.strip('$').astype(float) > 600.0),:]) #行中的值屬于某個集合 li = [2341,6650] print(df[df['Part Number'].isin(li)]) print(df.loc[df['Part Number'].astype(int).isin(li),:]) #行中的值匹配某個模式 print(df[df['Invoice Number'].str.startswith("001-")])
(3)選取特定的列
#選取特定的列 #列索引值,打印1,3列 print(df.iloc[:,1:4:2]) #列標題打印 print(df.loc[:,["Invoice Number", "Part Number"]]) #選取連續的行 print(df.loc[1:4,:])
看完上述內容是否對您有幫助呢?如果還想對相關知識有進一步的了解或閱讀更多相關文章,請關注創新互聯行業資訊頻道,感謝您對創新互聯的支持。
網站題目:pandas數據篩選和csv操作的實現方法-創新互聯
URL網址:http://vcdvsql.cn/article38/csidpp.html
成都網站建設公司_創新互聯,為您提供營銷型網站建設、服務器托管、網站建設、關鍵詞優化、云服務器、微信公眾號
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯