鉴于下面的python代码,请帮助我了解那里发生的事情。
start_time = time.time()
time.sleep(42)
end_time = time.time()
uptime = end_time - start_time
human_uptime = str(datetime.timedelta(seconds=int(uptime)))
所以我得到了start time
和end time
之间的区别,在第5行我通过施法来计算持续时间,现在是什么,进一步的解释是什么?
我知道delta意味着什么(平均值或差值),但为什么我必须将seconds = uptime
传递给timedelta
?为什么字符串转换工作得非常好以至于得到HH:MM:SS
?
答案 0 :(得分:107)
因为timedelta被定义为:
class datetime.timedelta([days,] [seconds,] [microseconds,] [milliseconds,] [minutes,] [hours,] [weeks])
所有参数都是可选的,默认为0。
你可以通过这种方式轻松说出“三天四毫秒”的可选参数。
>>> datetime.timedelta(days=3, milliseconds=4)
datetime.timedelta(3, 0, 4000)
>>> datetime.timedelta(3, 0, 0, 4) #no need for that.
datetime.timedelta(3, 0, 4000)
对于str转换,它返回一个很好的格式化值而不是__repr__
,以提高可读性。来自docs:
str(t)以[D day [s],] [H] H:MM:SS [.UUUUUU]的形式返回一个字符串, 其中D对负t为负。 (5)
>>> datetime.timedelta(seconds = 42).__repr__()
'datetime.timedelta(0, 42)'
>>> datetime.timedelta(seconds = 42).__str__()
'0:00:42'
结帐文件:
http://docs.python.org/library/datetime.html#timedelta-objects
答案 1 :(得分:12)
为什么我必须将秒=正常运行时间传递给timedelta
因为timedelta对象可以传递秒,毫秒,天等等所以你需要指定传入的内容(这就是你使用显式键的原因)。对int
进行类型转换是多余的,因为它们也可以接受浮点数。
为什么字符串转换工作得很好,我得到HH:MM:SS?
格式化的类型转换不是对象的内部__str__
方法。事实上,如果你写下来,你将获得相同的结果:
print datetime.timedelta(seconds=int(uptime))