Итерация в течение каждого квартала года

Я пытаюсь перебирать каждый квартал года, это то, что у меня есть до сих пор.

now = datetime.now()

first_day = datetime(year=now.year, month=1, day=1)
print("--",first_day)
hundredDaysLater = first_day - timedelta(days=100)

for dt in rrule.rrule(rrule.MONTHLY, dtstart=first_day, bymonthday=(31, -1), count=6, interval=3):
    print(dt.replace(day=1))
    print(dt)

выход

  -- 2018-01-01 00:00:00
    2018-01-01 00:00:00
    2018-01-31 00:00:00
    2018-04-01 00:00:00
    2018-04-30 00:00:00
    2018-07-01 00:00:00
    2018-07-31 00:00:00
    2018-10-01 00:00:00
    2018-10-31 00:00:00
    2019-01-01 00:00:00
    2019-01-31 00:00:00
    2019-04-01 00:00:00

Теперь мне в основном нужно получить этот вывод

2018-01-01, 2018-03-31
2018-04-01, 2018-06-30
2018-07-01, 2018-09-30
2018-10-01, 2018-12-31

Но вместо того, чтобы считать вперед, мне нужно считать назад.


person Sharpless512    schedule 23.12.2018    source источник
comment
обновите ожидаемый результат из-за вашего счета в обратном порядке   -  person RomanPerekhrest    schedule 23.12.2018


Ответы (2)


Использование relativedelta (из пакета dateutil):

>>> from dateutil.relativedelta import relativedelta                                                                                                                  
>>> from datetime import date 
>>> d = date(2019, 1, 1)                                                                                                                                              
>>> day = relativedelta(days=1)                                                                                                                                       
>>> quarter = relativedelta(months=3)                                                                                                                                 
>>> while True: 
...     print(d - day) 
...     print(d - quarter) 
...     d -= quarter 
...                                                                                                                                                                   
2018-12-31
2018-10-01
2018-09-30
2018-07-01
2018-06-30
2018-04-01
2018-03-31
2018-01-01
2017-12-31
2017-10-01
2017-09-30
2017-07-01
2017-06-30
2017-04-01
2017-03-31
...
person wim    schedule 23.12.2018

Краткое решение с pandas.date_range функция:

In [708]: start_date = datetime.datetime(2018, 1, 1)

In [709]: data = pd.date_range(start=start_date, periods=4, freq='QS-JAN').union(
                 pd.date_range(start=start_date, periods=4, freq='Q-DEC')).strftime('%Y-%m-%d')

In [710]: for i in range(0, data.size, 2):
     ...:     print(data[i], data[i+1], sep=', ')
     ...:     
2018-01-01, 2018-03-31
2018-04-01, 2018-06-30
2018-07-01, 2018-09-30
2018-10-01, 2018-12-31
person RomanPerekhrest    schedule 23.12.2018