Python日期和时间处理(三) - 周数转换

周数的转换

  • 日期转换周数
    当我们需要获取特定日期对应的周数的时候,通常我们使用如下方法:
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的标准是从周一开始到周日。

推荐阅读更多精彩内容