我有一个timedelta,我想四舍五入到最近的15分钟。例如,8h 40m将舍入为8h 45m,而8h 50m将舍入为8h 45m。
实现这一目标的最佳方法是什么?
最佳答案
由于找不到其他方法,我最终创建了自己的解决方案
def round_timedelta(td, period):
"""
Rounds the given timedelta by the given timedelta period
:param td: `timedelta` to round
:param period: `timedelta` period to round by.
"""
period_seconds = period.total_seconds()
half_period_seconds = period_seconds / 2
remainder = td.total_seconds() % period_seconds
if remainder >= half_period_seconds:
return timedelta(seconds=td.total_seconds() + (period_seconds - remainder))
else:
return timedelta(seconds=td.total_seconds() - remainder)
在iPython中使用:
In [4]: print round_timedelta(timedelta(hours=1, minutes=27), timedelta(minutes=15))
1:30:00
In [5]: print round_timedelta(timedelta(hours=1, minutes=30), timedelta(minutes=15))
1:30:00
In [6]: print round_timedelta(timedelta(hours=1, minutes=31), timedelta(minutes=15))
1:30:00
In [7]: print round_timedelta(timedelta(hours=1, minutes=37), timedelta(minutes=15))
1:30:00
In [8]: print round_timedelta(timedelta(hours=1, minutes=38), timedelta(minutes=15))
1:45:00
关于python - 将时间量取整到最接近的15分钟,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/42299312/