我有一个数据框 df_A,有两列“amin”和“amax”,这是一组时间范围。
我的目标是查找 df_B 中的列是否位于 df_A 'amin' 和 'amax' 列中范围的任何行之间。
df_A[['amin','amax'] ]
amin amax
0 2016-07-16 19:37:03 2016-07-17 11:16:32
1 2016-07-04 21:15:54 2016-07-05 10:57:46
2 2016-07-24 23:30:41 2016-07-25 15:38:02
3 2016-07-12 03:02:38 2016-07-12 22:11:01
df_B['created_date']
created_date
2016-07-17 01:16:32
2016-07-05 10:15:54
2016-07-12 12:11:01
df_A['amin'] = pd.to_datetime(df_A['amin'], errors='coerce')
df_A['amax'] = pd.to_datetime(df_A['amax'], errors='coerce')
df_B['created_date'] = pd.to_datetime(df_B['created_date'],errors='coerce')
def dt2epoch(value):
epoch = (value - pd.to_datetime(datetime(2015,12,31).strftime('%Y-%m-%d %H:%M:%S.%f'))).total_seconds()
return epoch
df_A['amax_epoch']=df_A['amax'].apply(dt2epoch)
df_A['amin_epoch']=df_A['amin'].apply(dt2epoch)
df_B['created_date_epoch']=df_B['created_date'].apply(dt2epoch)
def make_tuple(row):
n= len(row)
row = [(x,row[n - 1]) for x in row]
return …Run Code Online (Sandbox Code Playgroud)