Python - 从日期获取周数,并且 viceversa 不对应



我有以下问题:从给定日期开始,我需要找到该年的周数,然后找到该周的开始日和结束日。

day1= datetime.datetime(2015,9,28)
day2= datetime.datetime(2017,12,18)

查找周工作正常:

day1.isocalendar()
day2.isocalendar()

返回

(2015, 40, 1)
(2017, 51, 1)

这也对应于一些标准日历: http://whatweekisit.org/calendar-2015.html

然后我定义了以下函数:

def week_start_end(year,week):
'''Given year and week, returns the start and end day of the week
as datetime object'''
w = "%s-W%s"%(year,week)
s = datetime.datetime.strptime(w + '-1', "%Y-W%W-%w")#monday
e= datetime.datetime.strptime(w + '-0', "%Y-W%W-%w")#sunday
return (s,e)

当我用年份和星期作为参数调用它时:

week_start_end(2015,40)
week_start_end(2017,51)

返回以下内容:

(datetime.datetime(2015, 10, 5, 0, 0), datetime.datetime(2015, 10, 11, 0, 0))
(datetime.datetime(2017, 12, 18, 0, 0), datetime.datetime(2017, 12, 24, 0, 0))

如您所见,它在第二次约会中运行良好,但在第一次约会中效果不佳。尝试了几个实例,我意识到这个函数总是比 2015 年晚一周返回,但在 2016 年和 2017 年是正确的。

我找不到通过它的路。你能帮我吗?

为什么不使用 isoweek 库

from isoweek import Week
def week_start_end(year, week):
'''Given year and week, returns the start and end day of the week
as datetime object'''
w = Week(year, week)
s = w.monday()
e = w.sunday()
return (s,e)

最后

>>> week_start_end(2015, 40)
(datetime.date(2015, 9, 28), datetime.date(2015, 10, 4))
>>> week_start_end(2017, 51)
(datetime.date(2017, 12, 18), datetime.date(2017, 12, 24))

不同的周编号约定。使用 %W 获得的周数与 ISO 周数不同。我相信您可以使用%V获得ISO周数,但我还没有尝试过,它似乎取决于平台。

相关内容

最新更新