pandas中關(guān)于apply+lambda的應(yīng)用
apply(func [, args [, kwargs ]]) 函數(shù)用于當(dāng)函數(shù)參數(shù)已經(jīng)存在于一個元組或字典中時,間接地調(diào)用函數(shù)。args是一個包含將要提供給函數(shù)的按位置傳遞的參數(shù)的元組。如果省略了args,任 何參數(shù)都不會被傳遞,kwargs是一個包含關(guān)鍵字參數(shù)的字典。簡單說apply()的返回值就是func()的返回值,apply()的元素參數(shù)是有序的,元素的順序必須和func()形式參數(shù)的順序一致,與map的區(qū)別是前者針對column,后者針對元素
lambda是匿名函數(shù),即不再使用def的形式,可以簡化腳本,使結(jié)構(gòu)不冗余何簡潔
a = ?lambda x ?: x + 1? a(10) ? 11
兩者結(jié)合可以做很多很多事情,比如split在series里很多功能不可用,而index就可以做
比如有一串?dāng)?shù)據(jù)如下,要切分為總數(shù),正確數(shù),正確率,則可這樣做
96%(1368608/1412722)
97%(1389916/1427922)
97%(1338695/1373803)
96%(1691941/1745196)
95%(1878802/1971608)
97%(944218/968845)
96%(1294939/1336576)
import pandas as pd
#先生成一個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)
?
#切分原文中識別率總數(shù),采用apply + 匿名函數(shù)
#lambda 函數(shù)的意思是選取x的序列值 ,比如 x[6:9]
#index函數(shù)的意思是把當(dāng)前字符位置轉(zhuǎn)變?yōu)樗谖恢玫奈粩?shù)
#-1是最后一位
df1['正確數(shù)'] = df1.iloc[:,0].apply(lambda x : x[x.index('(') + 1 : x.index('/')])
df1['總數(shù)'] = df1.iloc[:,0].apply(lambda x : x[x.index('/') + 1 : -1])
df1['正確率'] = df1.iloc[:,0].apply(lambda x : x[:x.index('(')])
df1
示例2
由一組dataframe數(shù)據(jù),包括有數(shù)值型的三列氣象要素,由這三列通過公式計算人體舒適指數(shù)

應(yīng)用到的人體舒適指數(shù)計算公式:

import pandas as pd
import numpy as np
import math
path='D:\\data\\57582.csv' #文件路徑
data=pd.read_csv(path,index_col=0,encoding='gbk') #讀取數(shù)據(jù)有中文時用gbk解碼
#定義舒適指數(shù)公式函數(shù),結(jié)果保留1位小數(shù)
def get_CHB(T,RH,S):
return round(1.8*T-0.55*(1.8*T-26)*(1-RH/100)-3.2*math.sqrt(S)+32,1)
#增加一列CHB并計算數(shù)據(jù)后賦值
data['舒適指數(shù)']=data.apply(lambda x:get_CHB(x['平均氣溫'],x['平均相對濕度'],x['2M風(fēng)速']),axis=1)
#打印結(jié)果
print(data)
#保存結(jié)果
data.to_csv('D:\\CHB.csv',encoding='gbk')
代碼中使用了apply和lambda的組合,傳入的參數(shù)x為整個data數(shù)據(jù),在函數(shù)中引入的參數(shù)則是x[‘平均氣溫’],x[‘平均相對濕度’],x[‘2M風(fēng)速’],與自定義的函數(shù)get_CHB對應(yīng)。最后需使用axis=1來指定是對列進行運算。
結(jié)果如圖所示:

到此這篇關(guān)于pandas中關(guān)于apply+lambda的應(yīng)用的文章就介紹到這了,更多相關(guān)pandas apply+lambda內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Python strip lstrip rstrip使用方法
Python中的strip用于去除字符串的首位字符,同理,lstrip用于去除左邊的字符,rstrip用于去除右邊的字符。這三個函數(shù)都可傳入一個參數(shù),指定要去除的首尾字符。2008-09-09
Python實現(xiàn)視頻轉(zhuǎn)換為音頻的方法詳解
這篇文章主要為大家詳細Python如何將視頻轉(zhuǎn)換為音頻并將音頻文件保存到特定文件夾下,文中的示例代碼講解詳細,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2025-02-02
Python爬蟲實戰(zhàn)演練之采集糗事百科段子數(shù)據(jù)
讀萬卷書不如行萬里路,只學(xué)書上的理論是遠遠不夠的,只有在實戰(zhàn)中才能獲得能力的提升,本篇文章手把手帶你用Python采集糗事百科段子的數(shù)據(jù),大家可以在過程中查缺補漏,提升水平2021-10-10
Python實現(xiàn)簡單的文件傳輸與MySQL備份的腳本分享
這篇文章主要介紹了Python實現(xiàn)簡單的文件傳輸與MySQL備份的腳本分享,用到了socket與tarfile模塊,需要的朋友可以參考下2016-01-01
pip安裝python庫時報Failed?building?wheel?for?xxx錯誤的解決方法
最近在使用pip安裝python的時候遇到些問題,所以下面這篇文章主要給大家介紹了關(guān)于pip安裝python庫時報Failed?building?wheel?for?xxx錯誤的解決方法,需要的朋友可以參考下2023-01-01

