我希望找到两个日期范围之间的重叠日期,如下所示:
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,timedeltadef 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)
出于性能目的,您还可以在生成给定范围内的日期时将d1 timedelta(days = i)强制转换为str. 总结
以上是内存溢出为你收集整理的python中两个日期范围之间重叠的日期全部内容,希望文章能够帮你解决python中两个日期范围之间重叠的日期所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)