2009-01-13 33 views

Respuesta

782

Usted puede utilizar un objeto timedelta:

from datetime import datetime, timedelta 

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

si no ignora las zonas horarias, entonces [la respuesta es más compleja] (http://stackoverflow.com/a/25427822/4279). – jfs

+0

¿Funciona con meses, años, etc.? – JohnAndrews

+0

Además, ¿cómo lo relacionas con una fecha específica? Ver mi pregunta: http://stackoverflow.com/questions/43092508/first-available-date-previous-day-month-year – JohnAndrews

58

Reste datetime.timedelta(days=1)

21

Sólo para Elaborar un método alternativo y un caso de uso para el cual es útil:

  • Restar 1 día a partir de la fecha actual:
from datetime import datetime, timedelta 
print datetime.now() + timedelta(days=-1) # Here, I am adding a negative timedelta 
  • útil en el caso, Si desea añadir 5 días y restar 5 horas desde la fecha y hora actual. es decir, ¿cuál es el Fecha y hora 5 días a partir de ahora, pero 5 horas menos?
from datetime import datetime, timedelta 
print datetime.now() + timedelta(days=5, hours=-5) 

Es de manera similar se puede utilizar con otros parámetros por ejemplo, segundo, semanas, etc.

33

Si el objeto de fecha y hora Python es zona horaria consciente de lo que debe tener cuidado para evitar errores de todo transiciones de horario de verano (o cambios en UTC compensados ​​por otras razones):

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 

En general, day_ago y yesterday pueden diferir si el desplazamiento UTC para la zona horaria local ha cambiado en el último día.

Por ejemplo, el horario de verano/verano finaliza el domingo 2 de noviembre de 2014 a las 02:00:00 a.m. en América/Los_Angeles zona horaria, por lo tanto si:

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 

continuación day_ago y yesterday diferir:

  • day_ago es exactamente hace 24 horas (en relación con now), pero a las 11 horas, no a las 10 horas como now
  • yesterday es ayer a las 10 a.m., pero es hace 25 horas (en relación con now), no 24 horas.

pendulum module maneja automáticamente:

>>> 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]> 
+0

Sí, el horario de verano puede ser desagradable –

5

También a otra función agradable me gusta usar cuando quiero decir calcular primero/último día del último mes o otros timedeltas relativas etc. ...

La función relativedelta de dateutil función (una poderosa extensión de la lib de fecha y hora)

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 
6

existe módulo de flecha Genial

import arrow 
utc = arrow.utcnow() 
utc_yesterday = utc.shift(days=-1) 
print(utc, '\n', utc_yesterday) 

de salida:

2017-04-06T11:17:34.431397+00:00 
2017-04-05T11:17:34.431397+00:00 
Cuestiones relacionadas