我有两个数据帧,其中一个我想在另一个数据帧中找到最近的(以前的)日期
如果日期匹配,则我需要选择上一个日期
df_main
包含引用信息
对于df_sample
,我想在df_main
中的Time
中查找最近的(但以前的)条目。我可以使用method='ffill'
来实现这一点,但是如果Time
字段的日期是当天返回的日期-我希望它返回前一天-基本上是一个<
而不是<=
在我的示例df_res
中,我希望closest_val
列包含[ "n/a", 90, 90, 280, 280, 280]
import pandas as pd
dsample = {'Index': [1, 2, 3, 4, 5, 6],
'Time': ["2020-06-01", "2020-06-02", "2020-06-03", "2020-06-04" ,"2020-06-05" ,"2020-06-06"],
'Pred': [100, -200, 300, -400 , -500, 600]
}
dmain = {'Index': [1, 2, 3],
'Time': ["2020-06-01", "2020-06-03","2020-06-06"],
'Actual': [90, 280, 650]
}
def find_closest(x, df2):
df_res = df2.iloc[df2.index.get_loc(x['Time'], method='ffill')]
x['closest_time'] = df_res['Time']
x['closest_val'] = df_res['Actual']
return x
df_sample = pd.DataFrame(data=dsample)
df_main = pd.DataFrame(data=dmain)
df_sample = df_sample.set_index(pd.DatetimeIndex(df_sample['Time']))
df_main = df_main.set_index(pd.DatetimeIndex(df_main['Time']))
df_res = df_sample.apply(find_closest, df2=df_main ,axis=1)
使用
pd.merge_asof
(确保'Time'确实是datetime):输出为:
IIUC,我们可以对两个数据帧进行笛卡尔积,然后过滤出精确的匹配,然后应用一些逻辑计算出最近的日期
最后,我们将把您的extact和非精确匹配加入到最终的数据帧中
上面的变量有很多,但本质上,我们是在寻找时间上的差异,消除未来的任何差异,并删除保留过去最接近日期的值
相关问题 更多 >
编程相关推荐