2010-01-11 14 views

Odpowiedz

13

Można użyć month i day do tworzenia wartości, które mogą być używane do sortowania:

birthdays.sort(key = lambda d: (d.month, d.day)) 
7
l.sort(key = lambda x: x.timetuple()[1:3]) 
+0

BTW: Zakładam, że lista ma być obiektami datetime (jak wspomniano w pierwszej części pytania), a nie ciągami (jak pokazano w fragmencie kodu). –

+0

Tak, przepraszam za to. Zmieniłem przykład, aby odzwierciedlić to, co zamierzałem zrobić. :) –

3

Jeżeli terminy są przechowywane jako ciągi, można powiedzieć, że nie są, choć wygląda na to, że są-ty mogą używać dateutil dydaktycznego parser:

>>> 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)] 

Jeśli daty są w różnych formatach, można dać rozmyty parsowania strzał:

>>> bd = [parse(i,fuzzy=True) for i in bd] # replace line 4 above with this line 
Powiązane problemy