肯定有更简单的方法。我有一些需要经常刷新的对象,所以我想记录它们创建的时间,检查当前的时间戳,并在必要时刷新。

datetime。datetime已被证明是困难的,我不想深入研究ctime库。这类事情还有更简单的吗?


当前回答

如果你想计算两个已知日期之间的差值,可以像这样使用total_seconds:

import datetime as dt

a = dt.datetime(2013,12,30,23,59,59)
b = dt.datetime(2013,12,31,23,59,59)

(b-a).total_seconds()

86400.0

#note that seconds doesn't give you what you want:
(b-a).seconds

0

其他回答

这是一个对我有用的。

from datetime import datetime

date_format = "%H:%M:%S"

# You could also pass datetime.time object in this part and convert it to string.
time_start = str('09:00:00') 
time_end = str('18:00:00')

# Then get the difference here.    
diff = datetime.strptime(time_end, date_format) - datetime.strptime(time_start, date_format)

# Get the time in hours i.e. 9.60, 8.5
result = diff.seconds / 3600;

希望这能有所帮助!

我们在Python 2.7中有total_seconds()函数 请参阅下面的python 2.6代码

import datetime
import time  

def diffdates(d1, d2):
    #Date format: %Y-%m-%d %H:%M:%S
    return (time.mktime(time.strptime(d2,"%Y-%m-%d %H:%M:%S")) -
               time.mktime(time.strptime(d1, "%Y-%m-%d %H:%M:%S")))

d1 = datetime.now()
d2 = datetime.now() + timedelta(days=1)
diff = diffdates(d1, d2)

如果你想计算两个已知日期之间的差值,可以像这样使用total_seconds:

import datetime as dt

a = dt.datetime(2013,12,30,23,59,59)
b = dt.datetime(2013,12,31,23,59,59)

(b-a).total_seconds()

86400.0

#note that seconds doesn't give you what you want:
(b-a).seconds

0

>>> from datetime import datetime

>>>  a = datetime.now()

# wait a bit 
>>> b = datetime.now()

>>> d = b - a # yields a timedelta object
>>> d.seconds
7

(7将是你在上面等待的时间)

我找到了datetime。Datetime非常有用,所以如果你遇到了复杂或尴尬的情况,请告诉我们。

编辑:感谢@WoLpH指出,人们并不总是需要如此频繁地刷新,以至于日期时间会很接近。通过计算增量中的天数,可以处理更长的时间戳差异:

>>> a = datetime(2010, 12, 5)
>>> b = datetime(2010, 12, 7)
>>> d = b - a
>>> d.seconds
0
>>> d.days
2
>>> d.seconds + d.days * 86400
172800

另一种方法是使用时间戳值:

end_time.timestamp() - start_time.timestamp()