回答
作爲字符串列表?
timeList = [ '0:00:00', '0:00:15', '9:30:56' ]
totalSecs = 0
for tm in timeList:
timeParts = [int(s) for s in tm.split(':')]
totalSecs += (timeParts[0] * 60 + timeParts[1]) * 60 + timeParts[2]
totalSecs, sec = divmod(totalSecs, 60)
hr, min = divmod(totalSecs, 60)
print "%d:%02d:%02d" % (hr, min, sec)
結果:
9:31:11
我有這個數組作爲字符串描述..謝謝.... – Hulk 2010-05-06 12:36:00
+1只是爲了給'divmod()'一些airplay ...可惜沒有人曾勇敢地要求GvR實現'/%'和'/%='運算符;-) ...讀這個並且哭泣:'mins,secs /%= 60;小時,分鐘/%= 60;天,小時/%= 24' – 2010-05-06 12:54:35
@John:我個人覺得難以辨認。你必須記住LHS上的哪些東西是投入的紅利。它還創建了一個操作符返回一個元組的操作,該操作可以防止鏈式操作,這是二元操作符的全部要點。我發現'divmod'的方式非常清晰。 – 2010-05-06 18:55:52
假設你想添加了秒的總時間:
def parse_time(s):
hour, min, sec = s.split(':')
try:
hour = int(hour)
min = int(min)
sec = int(sec)
except ValueError:
# handle errors here, but this isn't a bad default to ignore errors
return 0
return hour * 60 * 60 + min * 60 + sec
print parse_time('0:00:00') + parse_time('0:00:15') + parse_time('9:30:56')
幼稚的做法(無異常處理):
#!/usr/bin/env python
def sumup(*times):
cumulative = 0
for t in times:
hours, minutes, seconds = t.split(":")
cumulative += 3600 * int(hours) + 60 * int(minutes) + int(seconds)
return cumulative
def hms(seconds):
"""Turn seconds into hh:mm:ss"""
hours = seconds/3600
seconds -= 3600*hours
minutes = seconds/60
seconds -= 60*minutes
return "%02d:%02d:%02d" % (hours, minutes, seconds)
if __name__ == '__main__':
print hms(sumup(*("0:00:00", "0:00:15", "9:30:56")))
# will print: 09:31:11
這取決於你有這些時間的形式,例如,如果你已經有了他們爲datetime.timedelta
S,那麼你可以只總結起來:
>>> s = datetime.timedelta(seconds=0) + datetime.timedelta(seconds=15) + datetime.timedelta(hours=9, minutes=30, seconds=56)
>>> str(s)
'9:31:11'
我認爲這是使用deltas最正確的解決方案 – dassouki 2010-05-06 12:21:22
lines = ["0:00:00", "0:00:15", "9:30:56"]
total = 0
for line in lines:
h, m, s = map(int, line.split(":"))
total += 3600*h + 60*m + s
print "%02d:%02d:%02d" % (total/3600, total/60 % 60, total % 60)
我真的很失望,如果沒有任何更Python的解決方案... :(
可怕的一個 - >
timeList = [ '0:00:00', '0:00:15', '9:30:56' ]
ttt = [map(int,i.split()[-1].split(':')) for i in timeList]
seconds=reduce(lambda x,y:x+y[0]*3600+y[1]*60+y[2],ttt,0)
#seconds == 34271
這一個看起來可怕太 - >
zero_time = datetime.datetime.strptime('0:0:0', '%H:%M:%S')
ttt=[datetime.datetime.strptime(i, '%H:%M:%S')-zero_time for i in timeList]
delta=sum(ttt,zero_time)-zero_time
# delta==datetime.timedelta(0, 34271)
# str(delta)=='9:31:11' # this seems good, but
# if we have more than 1 day we get for example str(delta)=='1 day, 1:05:22'
很無奈也在於此 - >
sum(ttt,zero_time).strftime('%H:%M:%S') # it is only "modulo" 24 :(
我真的想看到一個班輪所以,我試圖讓一個在python3:P(不錯的結果,但可怕的樣子)
import functools
timeList = ['0:00:00','0:00:15','9:30:56','21:00:00'] # notice additional 21 hours!
sum_fnc=lambda ttt:(lambda a:'%02d:%02d:%02d' % (divmod(divmod(a,60)[0],60)+(divmod(a,60)[1],)))((lambda a:functools.reduce(lambda x,y:x+y[0]*3600+y[1]*60+y[2],a,0))((lambda a:[list(map(int,i.split()[-1].split(':'))) for i in a])(ttt)))
# sum_fnc(timeList) -> '30:40:11'
使用timedeltas(在Python 3.4測試):
import datetime
timeList = ['0:00:00', '0:00:15', '9:30:56']
sum = datetime.timedelta()
for i in timeList:
(h, m, s) = i.split(':')
d = datetime.timedelta(hours=int(h), minutes=int(m), seconds=int(s))
sum += d
print(str(sum))
結果:
9:31:11
也可以在2.7中工作,因爲代碼可讀性強,直觀 – adelval 2015-06-19 05:34:23
貝婁是使用的解決方案減少和列表理解:
from functools import reduce
from datetime import timedelta
time_list = ['0:00:00', '0:00:15', '9:30:56']
total = reduce(lambda x, y: x + y,
[timedelta(hours=int(ms[0]), minutes=int(ms[1]), seconds=int(ms[2]))
for t in time_list
for ms in [t.split(':')]])
print(f'Total time: {total}')
總時間:9時31分11秒
- 1. 時間總結
- 2. 總結所有時間段
- 3. 總結一段時間
- 4. 鑄造和總結時間間隔值
- 5. 總結到一定的時間間隔
- 6. 總結在Python
- 7. python總結
- 8. python時間間隔算法總和
- 9. 只用python總結時間序列中的非NaN數據
- 10. Python要做一段時間總結一個列表的整數
- 11. Python - 沒有時間結果
- 12. 兩個時間戳總結在一起
- 13. 總結timedates的持續時間值
- 14. 如何總結TIMEDIFF的在時間
- 15. MySQL的 - 排序結果由總時間
- 16. 如何總結日期和時間?
- 17. 如何總結運行時間
- 18. LINQ - 獲取總查詢結果時間
- 19. 如何總結數組時間
- 20. SQL:總結時間字段是char類型的時間
- 21. Python - 日期時間的時間總是爲零
- 22. 總結MySQL中給定日期的總時間段
- 23. SSRS總時間
- 24. 轉換浮在python總結
- 25. 在read_csv總結值的Python
- 26. Python如何總結列表
- 27. 總結與Python C庫僅
- 28. 如何總結在python
- 29. 在Python Dataframe中總結行
- 30. Python的西格瑪總結
要從0:00:00加起來的差別我猜?即三角洲,而不是實際時間? – 2010-05-06 12:12:14
@steve:好了,deltas加起來就是'9:30:56' – SilentGhost 2010-05-06 12:13:35
我使用的是python 2.4,我不能使用strptime,是的,我想加上deltas,對於上面提到的例子,答案應該是9 :31:11 – Hulk 2010-05-06 12:18:12