I am not sure how to go about constructing datetime
object given year
, month
, week_of_month
and day_of_week
. Any clues? Using this I am trying to achieve following:
From (start_month, start_year)
to (end_month, end_year)
find monthly dates as specified by week_of_month
and day_of_week
parameters. Here 1 <= week_of_month <= 5
and 1 <= day_of_week <= 7
. Now,
- Each month may not have 5 weeks (eg. February in non-leap year)
- 1st and 5th week may not have 7 days.
In such cases, based on boolean is_to_next_day
, if True
then specify next calendar day, if False
then skip it.
Sample input/outputs:
- Input parameters:
start_month=1 start_year=2020, end_month=12, end_year=2020, week_of_month=5, day_of_week=3, is_to_next_day=True
Desired output:[datetime(2020, 1, 29), datetime(2020, 2, 26), datetime(2020, 3, 25), datetime(2020, 4, 29), datetime(2020, 5, 27), datetime(2020, 7, 1), datetime(2020, 7, 29), datetime(2020, 8, 26), datetime(2020, 9, 30), datetime(2020, 10, 28), datetime(2020, 11, 25), datetime(2020, 12, 30)]
- Input parameters:
start_month=1 start_year=2020, end_month=12, end_year=2020, week_of_month=5, day_of_week=3, is_to_next_day=False
Desired output:[datetime(2020, 1, 29), datetime(2020, 2, 26), datetime(2020, 3, 25), datetime(2020, 4, 29), datetime(2020, 5, 27), datetime(2020, 7, 29), datetime(2020, 8, 26), datetime(2020, 9, 30), datetime(2020, 10, 28), datetime(2020, 11, 25), datetime(2020, 12, 30)]