





Вы можете использовать объект timedelta:
from datetime import datetime, timedelta
d = datetime.today() - timedelta(days=days_to_subtract)
если вы не игнорируете часовые пояса, то ответ более сложный.
Кроме того, как вы соотносите это с конкретной датой. См. Мой вопрос: stackoverflow.com/questions/43092508/…
Он работает и с другими устройствами, я использовал его, например, с timedelta(minutes=12).
в документации указано, что будет возвращено «Продолжительность, выражающая разницу между двумя экземплярами даты, времени или даты и времени ...»., как вы можете получить фактическую дату, скажем, 5 дней назад или 5 дней с этого момента?
Вычтите datetime.timedelta(days=1)
Просто чтобы проработать альтернативный метод и вариант использования, для которого это полезно:
from datetime import datetime, timedelta print datetime.now() + timedelta(days=-1) # Here, I am adding a negative timedelta
from datetime import datetime, timedelta print datetime.now() + timedelta(days=5, hours=-5)
Аналогичным образом его можно использовать с другими параметрами, например. секунды, недели и т. д.
Если ваш объект Python datetime учитывает часовой пояс, вам следует быть осторожным, чтобы избежать ошибок, связанных с переходами на летнее время (или изменения смещения UTC по другим причинам):
from datetime import datetime, timedelta
from tzlocal import get_localzone # pip install tzlocal
DAY = timedelta(1)
local_tz = get_localzone() # get local timezone
now = datetime.now(local_tz) # get timezone-aware datetime object
day_ago = local_tz.normalize(now - DAY) # exactly 24 hours ago, time may differ
naive = now.replace(tzinfo=None) - DAY # same time
yesterday = local_tz.localize(naive, is_dst=None) # but elapsed hours may differ
В общем, day_ago и yesterday могут отличаться, если смещение UTC для местного часового пояса изменилось в последний день.
Например, переход на летнее и зимнее время заканчивается 2 ноября 2014 г. в 02:00:00. в часовом поясе America / Los_Angeles, поэтому, если:
import pytz # pip install pytz
local_tz = pytz.timezone('America/Los_Angeles')
now = local_tz.localize(datetime(2014, 11, 2, 10), is_dst=None)
# 2014-11-02 10:00:00 PST-0800
тогда day_ago и yesterday различаются:
day_ago ровно 24 часа назад (относительно now), но в 11 утра, а не в 10 утра, как nowyesterday вчера в 10 утра, но это 25 часов назад (относительно now), а не 24 часа.pendulum модуль обрабатывает это автоматически:
>>> import pendulum # $ pip install pendulum
>>> now = pendulum.create(2014, 11, 2, 10, tz='America/Los_Angeles')
>>> day_ago = now.subtract(hours=24) # exactly 24 hours ago
>>> yesterday = now.subtract(days=1) # yesterday at 10 am but it is 25 hours ago
>>> (now - day_ago).in_hours()
24
>>> (now - yesterday).in_hours()
25
>>> now
<Pendulum [2014-11-02T10:00:00-08:00]>
>>> day_ago
<Pendulum [2014-11-01T11:00:00-07:00]>
>>> yesterday
<Pendulum [2014-11-01T10:00:00-07:00]>
Также еще одна приятная функция, которую я люблю использовать, когда я хочу вычислить, то есть первый / последний день прошлого месяца или другие относительные timedeltas и т. Д ...
Функция relativedelta из функции dateutil (мощное расширение библиотеки datetime)
import datetime as dt
from dateutil.relativedelta import relativedelta
#get first and last day of this and last month)
today = dt.date.today()
first_day_this_month = dt.date(day=1, month=today.month, year=today.year)
last_day_last_month = first_day_this_month - relativedelta(days=1)
print (first_day_this_month, last_day_last_month)
>2015-03-01 2015-02-28
Модуль Genial arrow существует
import arrow
utc = arrow.utcnow()
utc_yesterday = utc.shift(days=-1)
print(utc, '\n', utc_yesterday)
выход:
2017-04-06T11:17:34.431397+00:00
2017-04-05T11:17:34.431397+00:00
связанные: Определите, прошло ли 24 часа между датами - Python