周数的转换
日期转换周数
当我们需要获取特定日期对应的周数的时候,通常我们使用如下方法:
from datetime import date
dt1 = date(2018, 10, 10)
dt2 = date(2018, 12, 31)
dt1.strftime("%V") # output: '41'
dt2.strftime("%V") # output '1'
可以看出周数显示的没有问题,但是对于d2,如果没有year会让我们无法清楚到底是2018年还是2019年的第一周,这会导致程序的一些错误。为避免这种混乱,我们需要一个函数来同时返回year和周数。
def get_week_number(dt):
"""get both year and week number of a specified date object
:param dt: date or datetime object which you want to corresponding get week number
:return: a tuple including both year and week number. (year, week_num)
"""
year = dt.year
month = dt.month
week_num = int(dt.strftime("%V"))
if dt.month == 12 and week_num == 1:
return year + 1, week_num
return year, week_num
调用结果如下:
get_week_number(d2)
# output: (2019, 1)
通过周数转化为特定日期
周数转化为特定日期时,我们其实不仅需要周数,还需要year和一周的第几天,这样才能知道具体是那一天,即:
year
week number
一周的第几天
最先想到的方法是如下方法:
dt3 = datetime.strptime("2018-41-3", "%Y-%W-%w")
dt3 # output: datetime.datetime(2018, 10, 10, 0, 0)
dt4 = datetime.strptime("2019-1-1", "%Y-%W-%w")
dt4 # output: datetime.datetime(2019, 1, 7, 0, 0)
dt5 = datetime.strptime("2018-41-0", "%Y-%W-%w")
dt5 # output: datetime.datetime(2018, 10, 14, 0, 0)
上面的示例dt3转换没有问题,但是对于dt4可以看出并不是我们想要的结果,我们会发现python在这里有一个bug的(当然也许只是计算方式不对,不论怎样,这里并没有遵循ISO的标准进行转换)。
另外一个问题是当我们想要获取第0天时,实际对应的是第7天(即周日)
解决这个问题需要安装一个新的第三方包isoweek,如下:
pip install isoweek
之后使用如下方法来获取对应的日期:
from isoweek import Week
dt6 = Week(2019, 1).monday()
dt6 # output: datetime.date(2018, 12, 31)
我们看到使用isoweek包,我们可以正确的将week number转化为对应的日期。另外需要说明的是iso的标准是从周一开始到周日。