如何使用python计算事件的开始时间和结束时间之间的经过时间,格式为00:00:00和23:59:59?
time.time()
只是系统时间,仅此而已。datetime
可能是一个计划,但如果你想DIY, divmod
工作得很好
def pretty_time(t):
"""takes a time, in seconds, and formats it for display"""
m, s = divmod(t, 60)
h, m = divmod(m, 60)
s = round(s) #Rounds seconds to the nearest whole number
h = str(h).rjust(2,'0') #covert to strings,
m = str(m).rjust(2,'0') #adding 0 if necessary to make
s = str(s).rjust(2,'0') #each one two digits long
return "{}:{}:{}".format(h,m,s)
然后用
调用pretty_time(end_time-start_time)
(例子:In [5]: pretty_time(3600)
Out[5]: '01:00:00'
In [6]: pretty_time(3500)
Out[6]: '00:58:20'
)
(请注意,我没有检查超过24小时的时间,它只会显示像"25:45:21"这样的内容)
我不确定如何使用time
模块,但您可以使用datetime
模块,在事件开始时获得datetime.datetime.now()
结果并将其保存在变量中。
然后当事件结束时,再次得到datetime.datetime.now()
并从中减去第一次。您将获得一个datetime.timedelta()
对象,您可以将其转换为str()
以获得所需格式的数据。
例子/演示-
>>> d = datetime.datetime.now()
>>> d1 = datetime.datetime.now()
>>> str(d1 - d)
'0:00:06.989000'
>>> str(datetime.timedelta(0,84332,12332))
'23:25:32.012332'
如果你不想要微秒部分,你可以在'.'
上使用rsplit()
并取第一部分,示例-
>>> str(d1 - d).rsplit('.',1)[0]
'0:00:06'
>>> str(datetime.timedelta(0,84332,12332)).rsplit('.',1)[0]
'23:25:32'