



下載本文檔
版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領
文檔簡介
第pandas中關于apply+lambda的應用apply(func[,args[,kwargs]])函數用于當函數參數已經存在于一個元組或字典中時,間接地調用函數。args是一個包含將要提供給函數的按位置傳遞的參數的元組。如果省略了args,任何參數都不會被傳遞,kwargs是一個包含關鍵字參數的字典。簡單說apply()的返回值就是func()的返回值,apply()的元素參數是有序的,元素的順序必須和func()形式參數的順序一致,與map的區別是前者針對column,后者針對元素
lambda是匿名函數,即不再使用def的形式,可以簡化腳本,使結構不冗余何簡潔
a=
lambdax
:x+1
a(10)
11
兩者結合可以做很多很多事情,比如split在series里很多功能不可用,而index就可以做
比如有一串數據如下,要切分為總數,正確數,正確率,則可這樣做
96%(1368608/1412722)
97%(1389916/1427922)
97%(1338695/1373803)
96%(1691941/1745196)
95%(1878802/1971608)
97%(944218/968845)
96%(1294939/1336576)
importpandasaspd
#先生成一個dataframe
d={"col1":["96%(1368608/1412722)",
"97%(1389916/1427922)",
"97%(1338695/1373803)",
"96%(1691941/1745196)",
"95%(1878802/1971608)",
"97%(944218/968845)",
"96%(1294939/1336576)"]}
df1=pd.DataFrame(d)
#切分原文中識別率總數,采用apply+匿名函數
#lambda函數的意思是選取x的序列值,比如x[6:9]
#index函數的意思是把當前字符位置轉變為所在位置的位數
#-1是最后一位
df1['正確數']=df1.iloc[:,0].apply(lambdax:x[x.index('(')+1:x.index('/')])
df1['總數']=df1.iloc[:,0].apply(lambdax:x[x.index('/')+1:-1])
df1['正確率']=df1.iloc[:,0].apply(lambdax:x[:x.index('(')])
df1
由一組dataframe數據,包括有數值型的三列氣象要素,由這三列通過公式計算人體舒適指數
應用到的人體舒適指數計算公式:
importpandasaspd
importnumpyasnp
importmath
path='D:\\data\\57582.csv'#文件路徑
data=pd.read_csv(path,index_col=0,encoding='gbk')#讀取數據有中文時用gbk解碼
#定義舒適指數公式函數,結果保留1位小數
defget_CHB(T,RH,S):
returnround(1.8*T-0.55*(1.8*T-26)*(1-RH/100)-3.2*math.sqrt(S)+32,1)
#增加一列CHB并計算數據后賦值
data['舒適指數']=data.apply(lambdax:get_CHB(x['平均氣溫'],x['平均相對濕度'],x['2M風速']),axis=1)
#打印結果
print(data)
#保存結果
data.to_csv('D:\\CHB.csv',encoding='gbk')
代碼中使用了apply和lambda的組合,傳入的參數x為整個data數據,在函數中引入的參數則是x[平均氣溫],x[平均相對濕度],x[2M風速],與自定義的函數get_CHB對應。最后需使用axis=1來指定是對列進行運算。
結果如圖所示:
到
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯系上傳者。文件的所有權益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
- 4. 未經權益所有人同意不得將文件中的內容挪作商業或盈利用途。
- 5. 人人文庫網僅提供信息存儲空間,僅對用戶上傳內容的表現方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
- 6. 下載文件中如有侵權或不適當內容,請與我們聯系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 網絡直播帶貨主播內容創作與平臺分成合作協議
- 個性化私人飛行訓練課程合同
- 離婚后房產使用權過渡及共同債務處理合同
- 元宇宙健康管理平臺數據共享合作協議
- 海外市場營銷活動執行補充協議
- 電影劇本著作權獨家授權合同
- 城市地鐵BIM運維模型交付與數據安全保密合同
- 跨界聯動:游戲IP與時尚電商合作開發協議
- 注冊會計師全職聘用及財務報表編制服務合同
- 碳中和綠色物流項目合作協議
- 織帶繪圖方法
- 防雷檢測能力評價考試題庫大全-下(簡答題匯總)
- 電纜橋架安裝施工方案-精品
- 青少年模擬法庭劇本(敲詐勒索)
- 萬用表校準報告
- 新聞采訪與寫作(馬工程筆記)
- DB32∕T 1703-2011 科技成果轉化服務規范總則
- SQ-02-綠色食品種植產品調查表0308
- 視頻結構化大數據平臺解決方案
- SolidWorks、CAD三維建模練習習題圖
- 光伏發電項目安全專項投資估算方案
評論
0/150
提交評論