私のスクリプトは2時間で差を計算します。このような:
lasted = datetime.strptime(previous_time, FMT) - datetime.strptime(current_time, FMT)
timedelta オブジェクトを返します。現在、それは私に秒単位の違いを与えます。
きれいに表示するようにフォーマットするにはどうすればよいですか?
たとえば、「121」を「00:02:01」に変換しますか?
ありがとうございました。
私のスクリプトは2時間で差を計算します。このような:
lasted = datetime.strptime(previous_time, FMT) - datetime.strptime(current_time, FMT)
timedelta オブジェクトを返します。現在、それは私に秒単位の違いを与えます。
きれいに表示するようにフォーマットするにはどうすればよいですか?
たとえば、「121」を「00:02:01」に変換しますか?
ありがとうございました。
使ってみましたstr()
か?
>>> a = datetime.now()
>>> b = datetime.now() - a
>>> b
datetime.timedelta(0, 6, 793600)
>>> str(b)
'0:00:06.793600'
または、文字列の書式設定を使用できます。
>>> a = datetime.now()
>>> b = datetime.now() - a
>>> s = b.total_seconds()
>>> '{:02}:{:02}:{:02}'.format(s // 3600, s % 3600 // 60, s % 60)
'00:00:06'
str
新しい timedelta オブジェクトを作成することで、使用時に秒を切り捨てることができます
>>> a = datetime.now()
>>> b = datetime.now()
>>> c = b-a
>>> str(c)
'0:00:10.327705'
>>> str(timedelta(seconds=c.seconds))
'0:00:10'
[恥知らずな自己宣伝の免責事項をここに挿入]
https://github.com/frnhr/django_timedeltatemplatefilterを使用できます
これは Django のテンプレート フィルターとしてパッケージ化されているため、重要な部分は単純な Python です。
def format_timedelta(value, time_format="{days} days, {hours2}:{minutes2}:{seconds2}"):
if hasattr(value, 'seconds'):
seconds = value.seconds + value.days * 24 * 3600
else:
seconds = int(value)
seconds_total = seconds
minutes = int(floor(seconds / 60))
minutes_total = minutes
seconds -= minutes * 60
hours = int(floor(minutes / 60))
hours_total = hours
minutes -= hours * 60
days = int(floor(hours / 24))
days_total = days
hours -= days * 24
years = int(floor(days / 365))
years_total = years
days -= years * 365
return time_format.format(**{
'seconds': seconds,
'seconds2': str(seconds).zfill(2),
'minutes': minutes,
'minutes2': str(minutes).zfill(2),
'hours': hours,
'hours2': str(hours).zfill(2),
'days': days,
'years': years,
'seconds_total': seconds_total,
'minutes_total': minutes_total,
'hours_total': hours_total,
'days_total': days_total,
'years_total': years_total,
})
これ以上簡単なことはありません :) それでも、readme でいくつかの例を確認してください。
あなたの例:
>>> format_timedelta(lasted, '{hours_total}:{minutes2}:{seconds2}')
0:02:01
これで問題が解決することを願っています。
import datetime
start = datetime.datetime(2012,11,16,11,02,59)
end = datetime.datetime(2012,11,20,16,22,53)
delta = end-start
print ':'.join(str(delta).split(':')[:3])
In [29]: import datetime
In [30]: start = datetime.datetime(2012,11,16,11,02,59)
In [31]: end = datetime.datetime(2012,11,20,16,22,53)
In [32]: delta = end-start
In [33]: print ':'.join(str(delta).split(':')[:3])
4 days, 5:19:54