Сортировка объектов даты и времени при игнорировании года? - PullRequest
8 голосов
/ 11 января 2010

У меня есть список дней рождения, хранящихся в datetime объектах.Как можно отсортировать их в Python, используя только аргументы month и day?

Например,

[
    datetime.datetime(1983, 1, 1, 0, 0)
    datetime.datetime(1996, 1, 13, 0 ,0)
    datetime.datetime(1976, 2, 6, 0, 0)
    ...
]

Спасибо!:)

Ответы [ 3 ]

13 голосов
/ 11 января 2010

Вы можете использовать month и day, чтобы создать значение, которое можно использовать для сортировки:

birthdays.sort(key = lambda d: (d.month, d.day))
7 голосов
/ 11 января 2010
l.sort(key = lambda x: x.timetuple()[1:3])
3 голосов
/ 11 января 2010

Если даты хранятся в виде строк - вы говорите, что это не так, хотя похоже, что они есть - вы можете использовать синтаксический анализатор dateutil :

>>> from dateutil.parser import parse
>>> from pprint import pprint
>>> bd = ['February 6, 1976','January 13, 1996','January 1, 1983']
>>> bd = [parse(i) for i in bd]
>>> pprint(bd)
[datetime.datetime(1976, 2, 6, 0, 0), 
 datetime.datetime(1996, 1, 13, 0, 0), 
 datetime.datetime(1983, 1, 1, 0, 0)]
>>> bd.sort(key = lambda d: (d.month, d.day)) # from sth's answer
>>> pprint(bd)
[datetime.datetime(1983, 1, 1, 0, 0),
 datetime.datetime(1996, 1, 13, 0, 0),
 datetime.datetime(1976, 2, 6, 0, 0)]

Если ваши даты в разных форматах, вы можете сделать нечеткий анализ:

>>> bd = [parse(i,fuzzy=True) for i in bd] # replace line 4 above with this line
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...