我希望找到两个日期范围之间的重叠日期,如下所示:
range1 = start(2016-06-01) end (2016-06-20)
range2 = start(2016-06-10) end (2016-06-13)
结果这里是4个日期(2016-06-10,2016-06-11,2016-06-12,2016-06-13).
另一个例子:
range1 = start(2016-06-01) end (2016-06-20) range2 = start(2016-06-18)
end (2016-06-25)
结果这里是3个日期(2016-06-18,2016-06-19,2016-06-20).
如果没有日期重叠,则结果为0个日期.
我发现this帖子有助于确定重叠日期的数量,但我想知道我是否可以在不使用长if / else语句的情况下获得实际日期?
提前致谢!
最佳答案
我建议在两个范围的每一个中生成日期,然后选择两个集合之间的交集.剪切这样做可能如下所示:
from datetime import date,timedelta
def f(d1,d2):
delta = d2 - d1
return set([d1 + timedelta(days=i) for i in range(delta.days + 1)])
range1 = [date(2016,6,1),date(2016,20)]
range2 = [date(2016,10),13)]
print f(*range1) & f(*range2)