亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

我可以動態選擇應用于 pandas Resampler 對象的方法嗎?

我可以動態選擇應用于 pandas Resampler 對象的方法嗎?

慕斯王 2023-05-16 15:13:36
我正在嘗試創建一個對pandas. 我希望可以選擇根據我發送的數據類型指定發生的聚合類型(即對于某些數據,取每個 bin 的總和是合適的,而對于其他數據,需要取平均值, ETC。)。例如像這樣的數據:import pandas as pdimport numpy as npdr = pd.date_range('01-01-2020', '01-03-2020', freq='1H')df = pd.DataFrame(np.random.rand(len(dr)), index=dr)我可以有這樣的功能:def process(df, freq='3H', method='sum'):    r = df.resample(freq)    if method == 'sum':        r = r.sum()    elif method == 'mean':        r = r.mean()    #...    #more options    #...    return r對于少量的聚合方法,這很好,但如果我想從所有可能的選項中進行選擇,這似乎很乏味。我希望用它getattr來實現類似這篇文章的東西(在“讓它發揮作用:泛化方法調用”下)。但是,我找不到這樣做的方法:def process2(df, freq='3H', method='sum'):    r = df.resample(freq)    foo = getattr(r, method)    return r.foo()#fails with:#AttributeError: 'DatetimeIndexResampler' object has no attribute 'foo'def process3(df, freq='3H', method='sum'):    r = df.resample(freq)    foo = getattr(r, method)    return foo(r)#fails with:#TypeError: __init__() missing 1 required positional argument: 'obj'我明白為什么process2會失?。ㄕ{用r.foo()查找方法foo(),r而不是變量foo)。但我不認為我明白為什么process3會失敗。我知道另一種方法是將函數傳遞給參數method,然后將apply這些函數傳遞給r. 我的傾向是這會降低效率嗎?而且它仍然不允許我直接訪問內置的 Resample 方法。有沒有一種更簡潔的工作方式來實現這一目標?謝謝!
查看完整描述

1 回答

?
不負相思意

TA貢獻1777條經驗 獲得超10個贊

嘗試.resample().apply(method)

但是除非您計劃在函數內部進行更多計算,否則硬編碼這一行可能會更容易。


查看完整回答
反對 回復 2023-05-16
  • 1 回答
  • 0 關注
  • 135 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號