亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

pandas中如何應用apply和lambda

發布時間:2022-02-28 16:11:24 來源:億速云 閱讀:221 作者:iii 欄目:開發技術

這篇“pandas中如何應用apply和lambda”文章的知識點大部分人都不太理解,所以小編給大家總結了以下內容,內容詳細,步驟清晰,具有一定的借鑒價值,希望大家閱讀完這篇文章能有所收獲,下面我們一起來看看這篇“pandas中如何應用apply和lambda”文章吧。

apply(func [, args [, kwargs ]]) 函數用于當函數參數已經存在于一個元組或字典中時,間接地調用函數。args是一個包含將要提供給函數的按位置傳遞的參數的元組。如果省略了args,任 何參數都不會被傳遞,kwargs是一個包含關鍵字參數的字典。簡單說apply()的返回值就是func()的返回值,apply()的元素參數是有序的,元素的順序必須和func()形式參數的順序一致,與map的區別是前者針對column,后者針對元素

lambda是匿名函數,即不再使用def的形式,可以簡化腳本,使結構不冗余何簡潔

a =  lambda x  : 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)

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)
 
#切分原文中識別率總數,采用apply + 匿名函數
#lambda 函數的意思是選取x的序列值 ,比如 x[6:9]
#index函數的意思是把當前字符位置轉變為所在位置的位數
#-1是最后一位
df1['正確數'] = df1.iloc[:,0].apply(lambda x : x[x.index('(') + 1 : x.index('/')])
df1['總數'] = df1.iloc[:,0].apply(lambda x : x[x.index('/') + 1 : -1])
df1['正確率'] = df1.iloc[:,0].apply(lambda x : x[:x.index('(')])
df1

pandas中如何應用apply和lambda

示例2

由一組dataframe數據,包括有數值型的三列氣象要素,由這三列通過公式計算人體舒適指數

pandas中如何應用apply和lambda

應用到的人體舒適指數計算公式:

pandas中如何應用apply和lambda

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')  #讀取數據有中文時用gbk解碼
#定義舒適指數公式函數,結果保留1位小數
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并計算數據后賦值
data['舒適指數']=data.apply(lambda x: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來指定是對列進行運算。

結果如圖所示:

pandas中如何應用apply和lambda

以上就是關于“pandas中如何應用apply和lambda”這篇文章的內容,相信大家都有了一定的了解,希望小編分享的內容對大家有幫助,若想了解更多相關的知識內容,請關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

泰宁县| 怀化市| 兴文县| 鞍山市| 仁寿县| 天长市| 定结县| 句容市| 徐州市| 满城县| 元江| 即墨市| 鸡西市| 宁海县| 西丰县| 密云县| 苗栗市| 天峻县| 色达县| 丰城市| 吴堡县| 益阳市| 永丰县| 依安县| 车致| 萨迦县| 建宁县| 横山县| 白山市| 长顺县| 龙井市| 稷山县| 龙胜| 呼玛县| 驻马店市| 抚顺市| 兴安盟| 逊克县| 饶阳县| 瑞昌市| 招远市|