Найти пятницу предыдущей / прошлой недели в Python

Eg1. Предположим, у меня есть день 4/30/07 . Затем мне нужно получить 4/27/07.

Eg2. Предположим, у меня есть день 6/29/07 . Затем мне нужно получить 6/22/07.

3 ответа

Решение

Если предположить, day это datetime.date или же datetime.datetime объект, этот код создает datetime/date объект для пятницы прошлой недели:

friday = day - timedelta(days=day.weekday()) + timedelta(days=4, weeks=-1)

Объяснение: timedelta(days=day.weekday()) смещение между понедельником и day так что если сложить 4 дня и вычесть одну неделю, вы получите пятницу на прошлой неделе.

Конечно, вы можете упростить это (+4d -1w = -3d):

friday = day - timedelta(days=day.weekday() + 3)

Примечание: чтобы получить timedeltaиспользовать from datetime import timedelta или просто import datetime и использовать datetime.timedelta

Другой и более простой способ - использовать http://labix.org/python-dateutil. Чтобы получить предыдущую пятницу:

>>> from dateutil.relativedelta import relativedelta, FR
>>> from datetime import datetime
>>> datetime(2015, 7, 8) + relativedelta(weekday=FR(-1))
datetime.datetime(2015, 7, 3, 0, 0)

И в следующую пятницу:

>>> datetime(2015, 7, 8) + relativedelta(weekday=FR(+1))
datetime.datetime(2015, 7, 10, 0, 0)

Не относится к пятнице, но с учетом дня "taget_dayofweek" (где понедельник 0 и воскресенье 6)

from datetime import datetime

target_dayofweek = 4  # Friday
current_dayofweek = datetime.now().weekday() # Today


if target_dayofweek <= current_dayofweek:
    # target is in the current week
    endDate = datetime.now() - timedelta(current_dayofweek - target_dayofweek)

else: 
    # target is in the previous week
    endDate = datetime.now() - timedelta(weeks=1) + timedelta(target_dayofweek - current_dayofweek)

В pandas.tseries.offsets есть множество опций. Это для пятницы предыдущей недели.

from pandas.tseries.offsets import Week
f_dates = required_df.index - Week(1, weekday=4)
date_object = datetime.date.today()
from dateutil.relativedelta import relativedelta
previousWeekLastDay = date_object + relativedelta(weekday=SU(-1))
previousWeekFirstDay = previousWeekLastDay + relativedelta(weekday=MO(-1))
print(previousWeekFirstDay)
print(previousWeekLastDay)

previoustopreviousWeekLastDay1= date_object + relativedelta(weekday=SU(-2))
previoustopreviousWeekFirstDay1= previousWeekLastDay1 + relativedelta(weekday=MO(-1))
print(previoustopreviousWeekFirstDay1)
print(previoustopreviousWeekLastDay1)
Другие вопросы по тегам