tky*_*ass 5 python date date-range
我希望找到两个日期范围之间的重叠日期,如下所示:
range1 = start(2016-06-01) end (2016-06-20)
range2 = start(2016-06-10) end (2016-06-13)
Run Code Online (Sandbox Code Playgroud)
结果是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)
Run Code Online (Sandbox Code Playgroud)
结果这里有3个日期(2016-06-18,2016-06-19,2016-06-20).如果没有日期重叠,则结果为0个日期.
我发现这篇文章有助于确定重叠日期的数量,但我想知道我是否可以在不使用长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, 6, 20)]
range2 = [date(2016, 6, 10), date(2016, 6, 13)]
print f(*range1) & f(*range2)
Run Code Online (Sandbox Code Playgroud)
出于性能目的,您还可以在生成给定范围内的日期时进行d1 + timedelta(days=i)转换。str