#! /usr/bin/python # coding=utf-8 from datetime import datetime,timedelta """ timedelta表明兩個datetime之間的時間差 """ now = datetime.now() past = past = datetime(2010,11,12,13,14,15,16) timespan = now - past #這會獲得一個負數 past - now attrs = [ ("days","日"),( 'seconds',"秒"),( 'microseconds',"毫秒") #('min',"最小"),( 'max',"最大"), ] for k,v in attrs: "timespan.%s = %s #%s" % (k,getattr(timespan, k),v) """ 總共相差的秒數 """ timespan.total_seconds() """ 實例化一個timespan 請注意它的參數順序 timedelta([days[, seconds[, microseconds[, milliseconds[, minutes[, hours[, weeks]]]]]]]) """ timespan = timedelta(days=1) now - timespan #返回的是datetime型 now + timespan timespan * 2 #還能夠乘哦。表明二倍 timespan / 13 #增長一個月 from calendar import monthrange now + timedelta(days=monthrange(start.year,start.month)[1])
實例2:python
‘’‘當前的時間上加一天或一年減一天等操做’‘’django
日期經常使用問題 app
在使用Django時,默認是開啓對多時區的支持的,在獲取時間的時候會是以下形式:python2.7
datetime.datetime(2014, 4, 18, 15, 37, 7, tzinfo=<UTC>)函數
咱們能夠利用django.utils.timezone中提供的localtime方法來將該時間轉換爲本地時間:post
1
2
3
4
|
>>> dt
datetime.datetime(
2014
,
4
,
18
,
15
,
37
,
7
, tzinfo
=
<UTC>)
>>> localtime(dt)
datetime.datetime(
2014
,
4
,
18
,
23
,
37
,
7
, tzinfo
=
<LocalTimezone>)
|
有時候,咱們須要將該時間與當前時間作比較,例如計算差值,你可能會想到直接這麼作:spa
1
2
3
|
>>>
import
datetime
>>> now
=
datetime.datetime.now()
>>> now
-
dt
|
不過這是不對的,並告知以下錯誤:code
1
2
3
|
Traceback (most recent call last):
File
"<console>"
, line
1
,
in
<module>
TypeError: can't subtract offset
-
naive
and
offset
-
aware datetimes
|
問題就出在利用datetime.datetime.now()獲得的當前時間是offset-naive的,而另一個倒是offset-aware的,所以咱們須要將這裏的dt轉成與now同樣的形式,能夠這麼作:blog
1
2
3
4
5
|
>>> dt
=
dt.replace(tzinfo
=
None
)
>>> dt
datetime.datetime(
2014
,
4
,
18
,
15
,
37
,
7
)
>>> now
-
dt
datetime.timedelta(
0
,
34108
,
443000
)
|
備註:1:timezone 獲取的日期增長和修改(好比加一天減一天) ip
from django.utiles import timezone
from datetime
t1 = timezone.now()
# torrow
t1+datetime.timedelta(days=1,hours=1)
2:python獲得兩個時間段的每一天的列表
begin_date = datetime.datetime.strptime(begin_date, "%Y-%m-%d") end_date = datetime.datetime.strptime(end_date, "%Y-%m-%d") while begin_date <= end_date: date_str = begin_date.strftime("%m-%d") date_list.append(date_str) begin_date += datetime.timedelta(days=1) print date_list
# 方法2(安裝boto3 庫 pip install boto3):
from datetime import datetime
from dateutil.rrule import rrule, DAILY
a = datetime(2009, 5, 30)
b = datetime(2009, 6, 9)
for dt in rrule(DAILY, dtstart=a, until=b):
print dt.strftime("%Y-%m-%d")
# 在原來日期上增長一年
from dateutil.relativedelta import relativedelta
from django.utils import timezone
t1 = timezone.now()
neww_year = t1 + relativedelta(years=1)