可以使用Python中的datetime模块和pandas库来解决此问题。
首先,我们定义一个函数来比较两个时间段是否有重叠:
from datetime import datetime
def is_overlap(slot1, slot2):
start1, end1 = map(datetime.fromisoformat, slot1)
start2, end2 = map(datetime.fromisoformat, slot2)
return start1 < end2 and start2 < end1
此函数将接受两个时间段,将其转换为datetime对象,然后比较它们是否有重叠。如果有重叠,则返回True,否则返回False。
接下来,我们将使用pandas库来将时间段转换为时间序列,并使用is_overlap函数来比较两个时间序列是否有重叠:
import pandas as pd
def compare_slots(slot1, slot2):
s1 = pd.date_range(start=slot1[0], end=slot1[1], freq='30min').to_series()
s2 = pd.date_range(start=slot2[0], end=slot2[1], freq='30min').to_series()
return s1.apply(lambda x: any(s2.apply(lambda y: is_overlap((x, x.replace(minute=30)), (y, y.replace(minute=30)))))).any()
此函数将接受两个时间段,并将它们转换为时间序列。然后,它将使用is_overlap函数比较两个时间序列中的每个时间点是否有重叠。如果有重叠,则返回True,否则返回False。
例如,我们可以比较以下两个时间段是否有重叠:
slot1 = ('2022-01-01T09:00:00', '2022-01-01T12:00:00')
slot2 = ('2022-01-01T11:00:00', '2022-01-01T14:00:00')
print(compare_slots(slot1, slot2))
输出为True,因为两个
上一篇:比较时间的更准确的方法
下一篇:比较时间和值