Сравнение даты и времени в Python - с часовыми поясами и без них
Часто при работе с датами вам нужно знать, наступает ли данная дата до или после другой даты. Мы можем получить эти ответы, сравнив даты.
В этой статье мы узнаем, как использовать Python модуль datetime для создания и сравнения как простых (без информации о часовом поясе), так и расширенных (с информацией о часовом поясе) дат.
Для сравнения даты, мы будем использовать операторы сравнения в Python: <, >, ==, <=, >=, !=.
Примечание. В модуле datetime есть два метода создания объекта дат - datetime.datetime и datetime.date. Сравнение можно проводить только с объектами, созданными из одного и того же класса:
datetime.datetime.now() >= datetime.date.today()
Это приведет к TypeError:
TypeError: can't compare datetime.datetime to datetime.date
Сравнение простых дат и времени по часовому поясу
Давайте начнем со сравнения простых дат, которые не имеют информации о часовом поясе. Во-первых, мы хотим импортировать модуль datetime:
from datetime import datetime, date
Затем давайте сделаем несколько дат, которые мы сможем сравнить:
date1 = date(1995, 3, 20)
date2 = date(2020, 1, 1)
dob_a = datetime(1995, 3, 20)
dob_b = datetime(2020, 1, 1)
Сравнивать эти объекты так же легко, как сравнивать, скажем, целые числа. Одна дата меньше другой, если ее время предшествует другой.
В нашем случае date1 считаются меньше (<), чем date2, потому что они находятся дальше во времени:
print("date1 comes before date2?", date1 < date2)
print("date1 comes after date2?", date1 > date2)
print("date1 is equal to date2?", date1 == date2)
Это приводит к:
date1 comes before date2? True
date1 comes after date2? False
date1 is equal to date2? False
Теперь вы обычно включаете эту логику в некоторые операторы управления потоком:
if dob_a > dob_b:
print("person a is older than person b")
else:
print("person b is older than person a")
Это приводит к:
person b is older than person a
Сравнение дат и времени с учетом часового пояса
Часовые пояса могут немного усложнить ситуацию, хотя, к счастью, мы можем применить ту же логику к сравнению. Единственная разница в том, что мы работаем с известными датами - датами с дополнительной информацией о часовом поясе, в котором они находятся:
from datetime import datetime
import pytz
# Create timezone objects for different parts of the world
tz_ny= pytz.timezone('America/New_York')
tz_lon = pytz.timezone("Europe/London")
# Year, Month, Day, Hour, Minute, Second
datetime = datetime(2010, 4, 20, 23, 30, 0)
# Localize the given date, according to the timezone objects
date_with_timezone_1 = tz_ny.localize(datetime)
date_with_timezone_2 = tz_lon.localize(datetime)
# These are now, effectively no longer the same *date* after being localized
print(date_with_timezone_1) # 2010-04-20 23:30:00-04:00
print(date_with_timezone_2) # 2010-04-20 23:30:00+01:00
print(date_with_timezone_1 == date_with_timezone_2)
Выполнение этого кода приводит к:
False
В то время как это утверждение:
print(date_with_timezone_1 > date_with_timezone_2)
Это приведет к:
True
Этот результат может показаться вам немного странным. Мы сравниваем эти две даты:
2010-04-20 23:30:00-04:00 # date_with_timezone_1
2010-04-20 23:30:00+01:00 # date_with_timezone_2
Интуитивно кажется, что date_with_timezone_2 действительно больше, чем date_with_timezone_1. Но давайте посмотрим, как работает функция localize().
Здесь мы использовали библиотеку pytz, чтобы сделать наши наивные свидания более понятными. Мы создали объект часового пояса для Нью-Йорка (tz_ny) и объект часового пояса для Лондона (tz_lon).
Затем, чтобы ввести информацию о часовом поясе в наш объект datetime, мы запустили функцию localize() и упаковали результат в date_with_timezone_1 и date_with_timezone_2.
Мы ввели 11: 30 вечера в localize(), который, в свою очередь, создал datetime для 11:30 вечера в Нью-Йорке и 11:30 вечера в Лондоне соответственно. Чтобы добраться с 11: 30 вечера в Нью-Йорке до 11: 30 вечера в Лондоне, вам придется добавить 4 часа. Прошло больше времени, чтобы добраться до Нью-Йорка к 11: 30 вечера, чем потребовалось, чтобы добраться до Лондона к 11:30 вечера. Таким образом, дата-время, соответствующее Нью-Йорку в 11:30 вечера, больше, чем дата-время, соответствующее Лондону в 11:30 вечера.
Помните об этом поведении при такой работе с часовыми поясами.
Однако стоит отметить, что сравнение дат c часовым поясом и без приведет к ошибке:
date_with_timezone = tz_ny.localize(datetime)
print(datetime == date_without_timezone)
Это приведет к следующей ошибке:
TypeError: can't compare offset-naive and offset-aware datetimes
Итак, чтобы сравнивать объекты datetime, оба объекта должны быть либо с часовым поясом, либо без.