#!/usr/bin/env python
from datetime import datetime, time as datetime_time, timedelta
def time_diff(start, end):
if isinstance(start, datetime_time): # convert to datetime
assert isinstance(end, datetime_time)
start, end = [datetime.combine(datetime.min, t) for t in [start, end]]
if start <= end: # e.g., 10:33:26-11:15:49
return end - start
else: # end < start e.g., 23:55:00-00:25:00
end += timedelta(1) # +day
assert end > start
return end - start
for time_range in ['10:33:26-11:15:49', '23:55:00-00:25:00']:
s, e = [datetime.strptime(t, '%H:%M:%S') for t in time_range.split('-')]
print(time_diff(s, e))
assert time_diff(s, e) == time_diff(s.time(), e.time())
这里有一个解决方案,支持查找差异,即使结束时间小于开始时间(超过午夜间隔),例如
23:55:00-00:25:00
(半小时持续时间):输出
time_diff()
返回一个timedelta对象,您可以将它(作为序列的一部分)直接传递给一个mean()
函数,例如:mean()
结果也是timedelta()
对象,您可以将其转换为秒(td.total_seconds()
方法(自Python 2.7以来))、小时(td / timedelta(hours=1)
(Python 3))等是的,这里绝对需要^{} 。特别是
strptime
函数,它将字符串解析为时间对象。这会得到一个
timedelta
对象,其中包含两次之间的差异。你可以用它做任何你想做的事情,例如把它转换成秒或者把它添加到另一个datetime
。如果结束时间早于开始时间(例如
s1 = 12:00:00
和s2 = 05:00:00
),则返回负结果。如果在这种情况下希望代码假定间隔跨越午夜(即假定结束时间永远不早于开始时间),则可以将以下行添加到上述代码中:(当然,您需要在某处包含
from datetime import timedelta
)。感谢J.F.Sebastian指出了这个用例。试试这个——它对短期事件的时间安排很有效。如果某个东西需要一个多小时,那么最终的显示可能需要一些友好的格式。
时间差返回为经过的秒数。
相关问题 更多 >
编程相关推荐