我想使用pandas滚动功能
https://pandas.pydata.org/pandas-docs/version/0.22/generated/pandas.DataFrame.rolling.html
在具有日期时间的pandas数据帧上聚合未来值。看起来只有在过去才能做到,这是准确的吗?
谢谢!
发布于 2018-07-23 20:55:44
IIUC,您可以使用shift将计算移回时间。
df = pd.DataFrame({'Data':np.arange(0,11,1)},index=pd.date_range('2018-07-23',periods=11))
df['rolling'] = df.rolling('2D').mean().shift(-1)
print(df)
输出:
Data rolling
2018-07-23 0 0.5
2018-07-24 1 1.5
2018-07-25 2 2.5
2018-07-26 3 3.5
2018-07-27 4 4.5
2018-07-28 5 5.5
2018-07-29 6 6.5
2018-07-30 7 7.5
2018-07-31 8 8.5
2018-08-01 9 9.5
2018-08-02 10 NaN
https://stackoverflow.com/questions/51487017
复制