据我所知,出于效率原因,秒和微秒可能会在datetime.timedelta
中单独表示,但我只写了这个简单的函数:
def to_seconds_float(timedelta):
"""Calculate floating point representation of combined
seconds/microseconds attributes in :param:`timedelta`.
:raise ValueError: If :param:`timedelta.days` is truthy.
>>> to_seconds_float(datetime.timedelta(seconds=1, milliseconds=500))
1.5
>>> too_big = datetime.timedelta(days=1, seconds=12)
>>> to_seconds_float(too_big) # doctest: +ELLIPSIS
Traceback (most recent call last):
...
ValueError: ('Must not have days', datetime.timedelta(1, 12))
"""
if timedelta.days:
raise ValueError('Must not have days', timedelta)
return timedelta.seconds + timedelta.microseconds / 1E6
这对于将值传递给time.sleep
或select.select
之类的内容非常有用。 为什么不是datetime.timedelta
界面的这一部分?我可能会遗漏一些角落案例。时间表示似乎有很多非明显的极端情况......
我拒绝了几天准确地进行了一次合理的拍摄(我太懒了,实际上没有计算出数学ATM,所以这似乎是一个合理的妥协; - )。
答案 0 :(得分:12)
Python float有大约15位有效数字,因此秒数高达86400(小数点左边5位数)和微秒需要6位数,你可以很好地包括天数(最多可达数年)不失精度。
一个好的口头禅是“pi秒是一个nanocentury” - 每100年大约3.14E9秒,即每年3E7,所以每年3E13微秒。口头禅是好的,因为它很难忘,即使它确实需要你之后做一点心算(但是,像菠菜一样,它对你有好处 - 让你保持敏捷和警觉! - )。
datetime
的设计理念有点极简主义,所以它省略了许多可能的辅助方法,这些方法归结为简单的算术表达式,这并不奇怪。
答案 1 :(得分:3)
您对精确度的关注是错误的。这是一个简单的双线程,用于计算大约有多少年可以挤入IEEE754 64位浮点数中53位预分频的左边:
>>> import math
>>> 10 ** (math.log10(2 ** 53) - math.log10(60 * 60 * 24) - 6) / 365.25
285.42092094268787
>>>
注意四舍五入;首先添加最小的非零数字:
return timedelta.seconds + timedelta.microseconds / 1E6 + timedelta.days * 86400