给定一个 datetime.time 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)

我不禁想到我缺少一种更简单的方法来做到这一点。

有关的

有帮助吗?

解决方案

您可以使用完整的 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

其他提示

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

sometime = get_some_time() # the time to which you want to add 3 seconds
later = (datetime.combine(date.today(), sometime) + timedelta(seconds=3)).time()

但是,我认为值得解释为什么需要完整的日期时间对象。考虑一下如果我在晚上 11 点之前增加 2 个小时会发生什么。什么是正确的行为?例外,因为时间不能超过晚上 11:59?是否应该绕回来?

不同的程序员会有不同的期望,因此无论他们选择哪个结果都会让很多人感到惊讶。更糟糕的是,程序员编写的代码在最初测试时运行得很好,然后由于做了一些意想不到的事情而导致代码崩溃。这是非常糟糕的,这就是为什么您不允许将 timedelta 对象添加到时间对象的原因。

一件小事,可能会增加清晰度以覆盖秒的默认值

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

感谢 @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.time 具有算术能力。当你过了午夜,它就会回到零。现在,“24 小时后是什么时间”有很多极端情况,包括夏令时、闰秒、历史时区变化等等。但有时你确实需要简单的情况,这就是它的作用。

你的例子可以这样写:

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

nptime 继承自 datetime.time, ,所以这些方法中的任何一个都应该可用。

它可以从 PyPi 获得 nptime (“非迂腐时间”),或在 GitHub 上: https://github.com/tgs/nptime

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

timedelta 用于日期和时间操作的类。 datetimedatetime 给出 timedelta, datetimetimedelta 给出 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.

为了完整起见,这是执行此操作的方法 arrow (Python 更好的日期和时间):

sometime = arrow.now()
abitlater = sometime.shift(seconds=3)

尝试添加一个 datetime.datetime 到一个 datetime.timedelta. 。如果您只想要时间部分,您可以调用 time() 方法对所得结果 datetime.datetime 对象得到它。

许可以下: CC-BY-SA归因
不隶属于 StackOverflow
scroll top