我有这两个数据帧df1
,df2
。
df1:
dateTime userId session
2018-08-30 02:20:19 2233 1
2018-08-30 05:32:10 1933 1
2018-08-30 09:10:39 2233 2
2018-08-30 10:26:59 2233 3
2018-08-30 11:56:25 4459 1
2018-08-30 12:30:55 4459 1
df2:
clickTime userId session clickId
2018-08-30 02:21:09 2233 1987
2018-08-30 02:23:19 2233 1988
2018-08-30 02:24:00 2233 1989
2018-08-30 02:32:09 2233 1990
2018-08-30 05:33:10 1933 2009
2018-08-30 05:35:19 1933 2010
2018-08-30 05:36:59 1933 2011
2018-08-30 11:57:25 4459 3012
2018-08-30 11:58:55 4459 3013
我想合并userId
上的两个数据帧以及时间范围列,例如10分钟。的df1
。
所以我想要的数据框是这样的:
dateTime userId session clickTime clickId
2018-08-30 02:20:19 2233 1 2018-08-30 02:21:09 1987
2018-08-30 02:20:19 2233 1 2018-08-30 02:23:19 1988
2018-08-30 02:20:19 2233 1 2018-08-30 02:21:09 1989
2018-08-30 02:20:19 2233 1 2018-08-30 02:21:09 1990
所以我想要每个用户使用它们,数据框应该看起来像这样,对于每个我想要这个数据框的userId
。可能吗?
因此,我想在df1
上合并df2
的{{1}}和userId
以及clickTime
的{{1}}的时间范围应该是10 df2
的{{1}}列的-15分钟。
答案 0 :(得分:1)
IIUC:使用pandas.merge_asof
pd.merge_asof(
df1, df2,
left_on='dateTime',
right_on='clickTime',
by='userId',
direction='nearest'
)
dateTime userId session clickTime clickId
0 2018-08-30 02:20:19 2233 1 2018-08-30 02:21:09 1987
1 2018-08-30 05:32:10 1933 1 2018-08-30 05:33:10 2009
2 2018-08-30 09:10:39 2233 2 2018-08-30 02:32:09 1990
3 2018-08-30 10:26:59 2233 3 2018-08-30 02:32:09 1990
4 2018-08-30 11:56:25 4459 1 2018-08-30 11:57:25 3012
5 2018-08-30 12:30:55 4459 1 2018-08-30 11:58:55 3013
您可以指定要看多远的公差
pd.merge_asof(
df1, df2,
left_on='dateTime',
right_on='clickTime',
by='userId',
direction='nearest',
tolerance=pd.Timedelta(15, unit='m')
)
dateTime userId session clickTime clickId
0 2018-08-30 02:20:19 2233 1 2018-08-30 02:21:09 1987.0
1 2018-08-30 05:32:10 1933 1 2018-08-30 05:33:10 2009.0
2 2018-08-30 09:10:39 2233 2 NaT NaN
3 2018-08-30 10:26:59 2233 3 NaT NaN
4 2018-08-30 11:56:25 4459 1 2018-08-30 11:57:25 3012.0
5 2018-08-30 12:30:55 4459 1 NaT NaN