秒から時間、分、秒までの経過時間をフォーマットするにはどうすればよいですか?
私のコード:
start = time.time()
... do something
elapsed = (time.time() - start)
実際の出力:
0.232999801636
望ましい/期待される出力:
00:00:00.23
入力に0.232999801636
などの時間を含める場合:
import time
start = time.time()
end = time.time()
hours, rem = divmod(end-start, 3600)
minutes, seconds = divmod(rem, 60)
print("{:0>2}:{:0>2}:{:05.2f}".format(int(hours),int(minutes),seconds))
例:
In [12]: def timer(start,end):
....: hours, rem = divmod(end-start, 3600)
....: minutes, seconds = divmod(rem, 60)
....: print("{:0>2}:{:0>2}:{:05.2f}".format(int(hours),int(minutes),seconds))
....:
In [13]: timer(12345.242,12356.434)
00:00:11.19
In [14]: timer(12300.242,12600.5452)
00:05:00.30
In [19]: timer(0.343,86500.8743)
24:01:40.53
In [16]: timer(0.343,865000.8743)
240:16:40.53
In [17]: timer(0,0.232999801636)
00:00:00.23
timedelta
を利用できます:
>>> from datetime import timedelta
>>> str(timedelta(seconds=elapsed))
'0:00:00.233000'
import time
start = time.time()
#do something
end = time.time()
temp = end-start
print(temp)
hours = temp//3600
temp = temp - 3600*hours
minutes = temp//60
seconds = temp - 60*minutes
print('%d:%d:%d' %(hours,minutes,seconds))