回答:
timedeltaオブジェクトを使用できます。
from datetime import datetime, timedelta
d = datetime.today() - timedelta(days=days_to_subtract)
timedelta(minutes=12)
ます。たとえば、私はそれを使っています。
import datetime as DT; DT.datetime.today()
Python 2と3の両方で動作します。これはと同等DT.datetime.now()
です。
Pythonのdatetimeオブジェクトがタイムゾーンに対応している場合は、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はオフセットが異なる場合があります。
たとえば、夏時間/夏時間は、2014年11月2日の米国の02:00:00 AM / 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時ではありません。now
yesterday
は昨日の午前10時ですがnow
、24時間ではなく25時間前(と比較)です。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]>
代わりの方法とそれが役立つユースケースを詳しく説明するために:
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)
同様に、秒、週などの他のパラメーターと一緒に使用できます。
また、私が計算したいときに使用したいもう1つの素晴らしい関数、つまり、先月の最初/最後の日や他の相対的な時間差など...
dateutil関数からのrelativedelta関数(datetime libの強力な拡張)
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