J'ai besoin de convertir les chaînes de valeur temporelles données dans le format suivant en secondes. J'utilise python2.6
par exemple:
1.'00:00:00,000' -> 0 seconds
2.'00:00:10,000' -> 10 seconds
3.'00:01:04,000' -> 64 seconds
4. '01:01:09,000' -> 3669 seconds
Dois-je utiliser regex pour faire cela? J'ai essayé d'utiliser le module de temps, mais time.strptime('00:00:00,000','%I:%M:%S')
a jeté
ValueError: time data '00:00:00,000' does not match format '%I:%M:%S'
Quelqu'un peut-il me dire comment cela peut être résolu?
Modifier:
Je pense
pt =datetime.datetime.strptime(timestring,'%H:%M:%S,%f')
total_seconds = pt.second+pt.minute*60+pt.hour*3600
donne la valeur correcte..J'ai utilisé le mauvais module
Pour Python 2.7:
>>> import datetime
>>> import time
>>> x = time.strptime('00:01:00,000'.split(',')[0],'%H:%M:%S')
>>> datetime.timedelta(hours=x.tm_hour,minutes=x.tm_min,seconds=x.tm_sec).total_seconds()
60.0
Un peu plus de façon pythonique je pense serait:
timestr = '00:04:23'
ftr = [3600,60,1]
sum([a*b for a,b in Zip(ftr, map(int,timestr.split(':')))])
La sortie est 263sec.
Je serais intéressé de voir si quelqu'un pourrait simplifier davantage.
sans importations
time = "01:34:11"
sum(x * int(t) for x, t in Zip([3600, 60, 1], time.split(":")))
Pour obtenir la timedelta()
, vous devez soustraire 1900-01-01
:
>>> from datetime import datetime
>>> datetime.strptime('01:01:09,000', '%H:%M:%S,%f')
datetime.datetime(1900, 1, 1, 1, 1, 9)
>>> td = datetime.strptime('01:01:09,000', '%H:%M:%S,%f') - datetime(1900,1,1)
>>> td
datetime.timedelta(0, 3669)
>>> td.total_seconds() # 2.7+
3669.0
%H
Ci-dessus implique que l'entrée est inférieure à un jour, afin de prendre en charge le décalage horaire plus d'un jour:
>>> import re
>>> from datetime import timedelta
>>> td = timedelta(**dict(Zip("hours minutes seconds milliseconds".split(),
... map(int, re.findall('\d+', '31:01:09,000')))))
>>> td
datetime.timedelta(1, 25269)
>>> td.total_seconds()
111669.0
Pour émuler .total_seconds()
sur Python 2.6:
>>> from __future__ import division
>>> ((td.days * 86400 + td.seconds) * 10**6 + td.microseconds) / 10**6
111669.0
On dirait que vous êtes prêt à effacer des fractions de seconde ... Le problème est que vous ne pouvez pas utiliser "00" comme heure avec %I
>>> time.strptime('00:00:00,000'.split(',')[0],'%H:%M:%S')
time.struct_time(tm_year=1900, tm_mon=1, tm_mday=1, tm_hour=0, tm_min=0, tm_sec=0, tm_wday=0, tm_yday=1, tm_isdst=-1)
>>>
Il y a toujours des analyses à la main
>>> import re
>>> ts = ['00:00:00,000', '00:00:10,000', '00:01:04,000', '01:01:09,000']
>>> for t in ts:
... times = map(int, re.split(r"[:,]", t))
... print t, times[0]*3600+times[1]*60+times[2]+times[3]/1000.
...
00:00:00,000 0.0
00:00:10,000 10.0
00:01:04,000 64.0
01:01:09,000 3669.0
>>>
import time
from datetime import datetime
t1 = datetime.now().replace(microsecond=0)
time.sleep(3)
now = datetime.now().replace(microsecond=0)
print((now - t1).total_seconds())
résultat: 3.0
Inspiré par sverrir-sigmundarson's commentaire:
def time_to_sec(time_str):
return sum(x * int(t) for x, t in Zip([1, 60, 3600], reversed(time_str.split(":"))))