





Похоже, это не поддерживается, так как не было бы хорошего способа справиться с переполнением в datetime.time. Я знаю, что это не прямой ответ, но, возможно, кто-то с большим опытом работы с Python, чем я, может пойти немного дальше. Для получения дополнительной информации см. Это: http://bugs.python.org/issue3250
Вы можете преобразовать оба значения в объекты timedelta и вычесть их друг из друга, что позаботится о переходящих остатках. Например:
>>> import datetime as dt
>>> t1 = dt.time(23, 5, 5, 5)
>>> t2 = dt.time(10, 5, 5, 5)
>>> dt1 = dt.timedelta(hours=t1.hour, minutes=t1.minute, seconds=t1.second, microseconds=t1.microsecond)
>>> dt2 = dt.timedelta(hours=t2.hour, minutes=t2.minute, seconds=t2.second, microseconds=t2.microsecond)
>>> print(dt1-dt2)
13:00:00
>>> print(dt2-dt1)
-1 day, 11:00:00
>>> print(abs(dt2-dt1))
13:00:00
Отрицательные объекты timedelta в Python получают отрицательное поле дня, а другие поля - положительные. Вы можете проверить заранее: сравнение работает как с объектами времени, так и с объектами timedelta:
>>> dt2 < dt1
True
>>> t2 < t1
True
Во-первых, обратите внимание, что datetime.time - это время дня, не зависящее от данного дня, поэтому разница между любыми двумя значениями datetime.time будет меньше 24 часов.
Один из подходов - преобразовать оба значения datetime.time в сопоставимые значения (например, миллисекунды) и найти разницу.
t1, t2 = datetime.time(...), datetime.time(...)
t1_ms = (t1.hour*60*60 + t1.minute*60 + t1.second)*1000 + t1.microsecond
t2_ms = (t2.hour*60*60 + t2.minute*60 + t2.second)*1000 + t2.microsecond
delta_ms = max([t1_ms, t2_ms]) - min([t1_ms, t2_ms])
Немного хромает, но работает.
Обратите внимание, что это решение не сохраняет знак. Кроме того, delta_ms = abs (t1_ms - t2_ms) немного проще для понимания и сохраняет, по крайней мере, вычитание.
не работает, если t1_ms до полуночи, а t2_ms после полуночи
Разве это не должно быть * 1000000? Поскольку 1 с = 1000000 мкс.
Также немного глупо, но вы можете попробовать выбрать произвольный день и каждый раз вставлять в него, используя datetime.datetime.combine, а затем вычитая:
>>> import datetime
>>> t1 = datetime.time(2,3,4)
>>> t2 = datetime.time(18,20,59)
>>> dummydate = datetime.date(2000,1,1)
>>> datetime.datetime.combine(dummydate,t2) - datetime.datetime.combine(dummydate,t1)
datetime.timedelta(0, 58675)
В Python есть модуль pytz (http://pytz.sourceforge.net), который можно использовать для арифметики объектов «время». Он также заботится о смещении DST. На приведенной выше странице есть несколько примеров, иллюстрирующих использование pytz.
нет смысла говорить о часовых поясах, зная только время, без указания Дата тоже. Если вы знаете дату и время, тогда может использоваться несколько определений различия
Получите время в миллисекундах, а затем выполните вычитание.
Environment.TickCount, кажется, работает хорошо, если вам нужно что-то быстрое.
int start = Environment.TickCount
...Сделай что-нибудь()
int elapsedtime = Environment.TickCount - начало
Джон
Крисс: Вы могли бы серьезно преуспеть с примером здесь.