在Python中如何标准地为datetime.time添加N秒?

532 投票
11 回答
561234 浏览
提问于 2025-04-11 09:16

在Python中,如果有一个datetime.time的时间值,想要给它加上一个整数秒数,有没有标准的方法呢?比如说,11:34:59 加上 3 秒,结果应该是 11:35:02

一些显而易见的想法并不能解决这个问题:

>>> datetime.time(11, 34, 59) + 3
TypeError: unsupported operand type(s) for +: 'datetime.time' and 'int'
>>> datetime.time(11, 34, 59) + datetime.timedelta(0, 3)
TypeError: unsupported operand type(s) for +: 'datetime.time' and 'datetime.timedelta'
>>> datetime.time(11, 34, 59) + datetime.time(0, 0, 3)
TypeError: unsupported operand type(s) for +: 'datetime.time' and 'datetime.time'

最后我写了这样的函数:

def add_secs_to_time(timeval, secs_to_add):
    secs = timeval.hour * 3600 + timeval.minute * 60 + timeval.second
    secs += secs_to_add
    return datetime.time(secs // 3600, (secs % 3600) // 60, secs % 60)

不过我总觉得我可能错过了更简单的方法。

相关链接

11 个回答

32

有一点小建议,可以更清楚地说明如何覆盖默认的秒数值。

>>> b = a + datetime.timedelta(seconds=3000)
>>> b
datetime.datetime(1, 1, 1, 12, 24, 59)
79

正如其他人所说的,你可以在整个程序中使用完整的日期时间对象:

from datetime import datetime, date, time, timedelta
sometime = time(8,00) # 8am
later = (datetime.combine(date.today(), sometime) + timedelta(seconds=3)).time()

不过,我觉得有必要解释一下为什么需要完整的日期时间对象。想象一下,如果我在晚上11点加上2个小时,会发生什么?正确的结果是什么?是抛出一个错误,因为你不能有超过11:59pm的时间吗?还是应该回到凌晨0点?

不同的程序员会有不同的期待,所以无论他们选择哪个结果,都会让很多人感到意外。更糟糕的是,程序员在最初测试代码时可能一切正常,但后来却因为一些意外情况导致代码出错。这是非常糟糕的,这就是为什么你不能把时间对象和时间差对象相加的原因。

716

你可以使用完整的 datetime 变量和 timedelta,通过提供一个虚拟的日期,然后使用 time 来获取时间值。

举个例子:

import datetime
a = datetime.datetime(100,1,1,11,34,59)
b = a + datetime.timedelta(0,3) # days, seconds, then other fields.
print(a.time())
print(b.time())

这样会得到两个值,相差三秒:

11:34:59
11:35:02

你也可以选择更易读的方式

b = a + datetime.timedelta(seconds=3)

如果你愿意的话。


如果你想要一个可以做到这个的函数,可以看看下面的 addSecs

import datetime

def addSecs(tm, secs):
    fulldate = datetime.datetime(100, 1, 1, tm.hour, tm.minute, tm.second)
    fulldate = fulldate + datetime.timedelta(seconds=secs)
    return fulldate.time()

a = datetime.datetime.now().time()
b = addSecs(a, 300)
print(a)
print(b)

这个输出结果是:

 09:11:55.775695
 09:16:55

撰写回答