出于一般性的兴趣,我想知道是否有更优雅/高效的方法来完成这个任务。我有一个函数,它比较两个起始/结束日期元组,如果它们相交,则返回 true。
from datetime import date
def date_intersection(t1, t2):
t1start, t1end = t1[0], t1[1]
t2start, t2end = t2[0], t2[1]
if t1end < t2start: return False
if t1end == t2start: return True
if t1start == t2start: return True
if t1start < t2start and t2start < t1end: return True
if t1start > t2start and t1end < t2end: return True
if t1start < t2start and t1end > t2end: return True
if t1start < t2end and t1end > t2end: return True
if t1start > t2start and t1start < t2end: return True
if t1start == t2end: return True
if t1end == t2end: return True
if t1start > t2end: return False
所以如果:
d1 = date(2000, 1, 10)
d2 = date(2000, 1, 11)
d3 = date(2000, 1, 12)
d4 = date(2000, 1, 13)
然后:
>>> date_intersection((d1,d2),(d3,d4))
False
>>> date_intersection((d1,d2),(d2,d3))
True
>>> date_intersection((d1,d3),(d2,d4))
True
等等。
我很好奇是否有更Pythonic/优雅/高效/简洁/通常更好的方法来使用mxDateTime或一些巧妙的timedelta或set()?
如果找到交集,函数返回开始/结束元组的另一种有用形式。
谢谢。
t1 ⇔ t2
的持续时间,我正在考虑下一个部分。http://docs.python.org/library/datetime.html#datetime.timedelta - msw