Как вычесть день из даты?


Ответы:


1293

Вы можете использовать объект timedelta :

from datetime import datetime, timedelta

d = datetime.today() - timedelta(days=days_to_subtract)

14
если вы не игнорируете часовые пояса, ответ будет более сложным .
Jfs

Кроме того, как вы связываете это с конкретной датой. Смотрите мой вопрос: stackoverflow.com/questions/43092508/…
JohnAndrews

7
в Python 3 это просто: импорт datetime и затем d = datetime.today () - datetime.timedelta (days = days_to_subtract)
Алекс

Он работает и с другими устройствами, я использовал его, timedelta(minutes=12)например.
Нагев

@legalalien: проверьте, что ваши операторы импорта: import datetime as DT; DT.datetime.today()работают на Python 2 и 3. Это эквивалентно DT.datetime.now().
JFS


62

Если ваш объект даты и времени Python учитывает временную зону, вы должны быть осторожны, чтобы избежать ошибок при переходах DST (или изменений в смещении 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 в часовом поясе Америки / Лос-Анджелеса, поэтому, если:

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 утра, какnow
  • yesterdayвчера в 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]>

41

Просто для разработки альтернативного метода и варианта использования, для которого это полезно:

  • Вычтите 1 день из текущей даты и времени:
from datetime import datetime, timedelta
print datetime.now() + timedelta(days=-1)  # Here, I am adding a negative timedelta
  • Полезно в случае , если вы хотите добавить 5 дней и вычесть 5 часов из текущей даты и времени. т.е. что такое Datetime через 5 дней, но на 5 часов меньше?
from datetime import datetime, timedelta
print datetime.now() + timedelta(days=5, hours=-5)

Он также может использоваться с другими параметрами, например, секундами, неделями и т. Д.


8

Также просто еще одна приятная функция, которую я хотел бы использовать, когда я хочу вычислить, то есть первый / последний день прошлого месяца или другие относительные временные интервалы и т. Д. ...

Функцияlativedelta из функции 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

7

Модуль 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
Используя наш сайт, вы подтверждаете, что прочитали и поняли нашу Политику в отношении файлов cookie и Политику конфиденциальности.
Licensed under cc by-sa 3.0 with attribution required.