给定一个日期时间。在Python中,是否有一种标准的方法来添加一个整数秒数,例如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)

我不禁想,我错过了一个更简单的方法来做到这一点。

相关的

Python time + timedelta等价


当前回答

感谢@Pax Diablo, @bvmou和@Arachnid建议在整个过程中使用完整的日期时间。如果我必须接受datetime。Time对象,那么这似乎是一个备选的add_secs_to_time()函数:

def add_secs_to_time(timeval, secs_to_add):
    dummy_date = datetime.date(1, 1, 1)
    full_datetime = datetime.datetime.combine(dummy_date, timeval)
    added_datetime = full_datetime + datetime.timedelta(seconds=secs_to_add)
    return added_datetime.time()

这段冗长的代码可以压缩为一行代码:

(datetime.datetime.combine(datetime.date(1, 1, 1), timeval) + datetime.timedelta(seconds=secs_to_add)).time()

但我想为了代码清晰,我想把它包装在一个函数中。

其他回答

正如其他人所说,你可以在整个过程中使用完整的datetime对象:

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

但是,我认为有必要解释一下为什么需要完整的datetime对象。想想如果我把晚上11点加2个小时会发生什么。什么是正确的行为?一个例外,因为你的时间不能大于晚上11:59 ?应该绕回去吗?

不同的程序员会期望不同的东西,所以他们选择的任何结果都会让很多人感到惊讶。更糟糕的是,程序员编写的代码在最初测试时工作得很好,但后来却因为做了一些意想不到的事情而导致代码崩溃。这是非常糟糕的,这就是为什么不允许将timedelta对象添加到time对象。

感谢@Pax Diablo, @bvmou和@Arachnid建议在整个过程中使用完整的日期时间。如果我必须接受datetime。Time对象,那么这似乎是一个备选的add_secs_to_time()函数:

def add_secs_to_time(timeval, secs_to_add):
    dummy_date = datetime.date(1, 1, 1)
    full_datetime = datetime.datetime.combine(dummy_date, timeval)
    added_datetime = full_datetime + datetime.timedelta(seconds=secs_to_add)
    return added_datetime.time()

这段冗长的代码可以压缩为一行代码:

(datetime.datetime.combine(datetime.date(1, 1, 1), timeval) + datetime.timedelta(seconds=secs_to_add)).time()

但我想为了代码清晰,我想把它包装在一个函数中。

如果你还没有timedelta对象,另一种可能是用旧对象的属性初始化一个新的time对象,并在需要的地方添加值:

   new_time:time = time(
       hour=curr_time.hour + n_hours,
       minute=curr_time.minute + n_minutes,
       seconds=curr_time.second + n_seconds
    )

诚然,这只在对值做了一些假设的情况下才有效,因为这里没有处理溢出。但我觉得有必要记住这一点 因为它可以节省一两行

您不能简单地将number添加到datetime,因为它不清楚使用什么单位:秒、小时、周……

timedelta类用于操作日期和时间。Datetime减去Datetime得到timedelta, Datetime加上timedelta得到Datetime,两个Datetime对象不能被添加,尽管两个timedelta可以被添加。

创建timedelta对象,并将其添加到datetime对象中:

>>> from datetime import datetime, timedelta
>>> t = datetime.now() + timedelta(seconds=3000)
>>> print(t)
datetime.datetime(2018, 1, 17, 21, 47, 13, 90244)

在c++中也有同样的概念:std::chrono::duration。

如果值得向您的项目添加另一个文件/依赖项,我刚刚编写了一个扩展datetime的小类。时间与做算术的能力。当你过了午夜,它就接近零了。现在,“24小时后是什么时间”有很多极端情况,包括夏令时、闰秒、历史时区更改等等。但有时你确实需要简单的情况,这就是它的作用。

你的例子可以这样写:

>>> import datetime
>>> import nptime
>>> nptime.nptime(11, 34, 59) + datetime.timedelta(0, 3)
nptime(11, 35, 2)

Nptime继承自datetime。时间,所以这些方法都应该是可用的。

它可以在PyPi上以nptime(“非学究时间”)的形式提供,也可以在GitHub上:https://github.com/tgs/nptime