сортировать кортежи в списках в Python - PullRequest
1 голос
/ 12 декабря 2010

Мне было интересно, есть ли какой-нибудь простой способ сортировки кортежей в списках в python, например, если у меня есть список:

list01 = ([a,b,c],[b,a,d],[d,e,c],[a,f,d])

и я бы отсортировал, я бы получил:

([a,b,c],[a,b,d],[c,d,e],[a,d,f])?

или даже:

([a,b,c],[a,b,d],[a,d,f],[c,d,e]) 

если так проще

Спасибо заранее:)

Ответы [ 3 ]

6 голосов
/ 12 декабря 2010
>>> list01 = (['a','b','c'],['b','a','d'],['d','e','c'],['a','f','d'])
>>> map(sorted, list01)
[['a', 'b', 'c'], ['a', 'b', 'd'], ['c', 'd', 'e'], ['a', 'd', 'f']]
>>> sorted(map(sorted, list01))
[['a', 'b', 'c'], ['a', 'b', 'd'], ['a', 'd', 'f'], ['c', 'd', 'e']]
2 голосов
/ 12 декабря 2010

Вы можете использовать генератор вместо:

>>> list01 = (['a','b','c'],['b','a','d'],['d','e','c'],['a','f','d'])
>>> tuple((sorted(item) for item in list01))
(['a', 'b', 'c'], ['a', 'b', 'd'], ['c', 'd', 'e'], ['a', 'd', 'f'])

Карта быстрее, кстати. ;)

In [48]: timeit tuple(map(sorted, list01))
100000 loops, best of 3: 3.71 us per loop

In [49]: timeit tuple((sorted(item) for item in list01))
100000 loops, best of 3: 7.26 us per loop

Изменить: сортировка на месте еще быстрее (спасибо Карл):

In [120]: timeit [item.sort() for item in list01 if False]
1000000 loops, best of 3: 490 ns per loop
2 голосов
/ 12 декабря 2010

Просто так ...

list01 = (['a','b','c'],['b','a','d'],['d','e','c'],['a','f','d'])

print(sorted(map(sorted,list01)))
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...