从python中的datetime对象中查找年份和季度

Ami*_*tad 4 python datetime

鉴于某个日期,我要求找到完成的季度(从1月到12月的1到4).请注意,它不是当前季度,而是完成的季度.我的意思是,如果1月1日是输入日期,那么完成的季度是4而不是1.我的小代码片段如下:

>>> import datetime
>>> import math
>>> now = datetime.datetime(2015, 1, 1, 0, 0, 0, 0)
>>> present_quarter = int(math.ceil(now.month/3.))
>>> completed_quarter = (present_quarter - 1) if present_quarter != 1 else 4
>>> completed_quarter
4
Run Code Online (Sandbox Code Playgroud)

然而,我需要的是年份,所以输出是:

2014-4
Run Code Online (Sandbox Code Playgroud)

做这个的最好方式是什么 ?输出是否仍然是一个日期时间对象而不是一个字符串,我的意思是Python支持像Year-Quarter这样的日期时间对象

Mar*_*ers 5

您可以简单地将月份映射到季度和年度增量(您需要去年第四季度):

def completed_quarter(dt):
    prev_quarter_map = ((4, -1), (1, 0), (2, 0), (3, 0))
    quarter, yd = prev_quarter_map[(dt.month - 1) // 3]
    return (dt.year + yd, quarter)
Run Code Online (Sandbox Code Playgroud)

这会将月份转换为0到3之间的值,然后将其转换为四分之一数字和年份增量.将年度增量添加到当前年份可为您在上一季度完成的年份提供正确的年份.

演示:

>>> def completed_quarter(dt):
...     prev_quarter_map = ((4, -1), (1, 0), (2, 0), (3, 0))
...     quarter, yd = prev_quarter_map[(dt.month - 1) // 3]
...     return (dt.year + yd, quarter)
... 
>>> from datetime import date
>>> completed_quarter(date(2015, 1, 12))
(2014, 4)
>>> completed_quarter(date(2015, 8, 31))
(2015, 2)
>>> completed_quarter(date(2015, 12, 31))
(2015, 3)
Run Code Online (Sandbox Code Playgroud)

datetime模块没有可以模拟四分之一的对象; 您可以拥有一个日期(必须具有有效的年,月和日值)或日期和时间(添加有效的小时,分​​钟,秒和微秒值,以及可选的时区).