Funkcja sortowana() w Pythonie zwraca posortowaną listę. Jest zdefiniowany nie tylko dla listy i akceptuje dowolną iterację (lista, krotka, ciąg znaków itp.).
Przykład
Python3
print>(>sorted>([>4>,>1>,>3>,>2>]))> |
>
>Wyjście
[1, 2, 3, 4]>
Składnia funkcji sorted() w Pythonie
posortowane(iterowalne, kluczowe, odwrotne)
Parametry:
- Iterowalne: sekwencja (lista, krotka, ciąg) lub kolekcja (słownik, zestaw, zestaw zamrożony) lub dowolny inny iterator, który wymaga sortowania.
- Klucz (opcjonalny): Funkcja, która mogłaby służyć jako klucz lub podstawa porównania sortowania.
- Odwracać (opcjonalny): Jeśli ma wartość True, iterowalna wartość zostanie posortowana w odwrotnej (malejącej) kolejności, domyślnie ustawiona jest wartość False.
Powrót: Zwraca listę elementów w posortowanej kolejności.
Jak korzystać z funkcji sorted() w Pythonie?
Korzystanie z funkcji sorted() jest bardzo proste. Jest to wbudowana funkcja w Pythonie i można jej używać z dowolną iterowalną funkcją. Rozumiemy to lepiej na przykładzie:
Przykład:
Python3
# creating a list> counting>=> [>4>,>1>,>5>,>2>,>3>]> #print sorted list> print>(>sorted>(counting))> |
>
>Wyjście
[1, 2, 3, 4, 5]>
Więcej przykładów funkcji Sorted().
Przyjrzyjmy się niektórym przypadkom użycia funkcji sorted():
1. Sortowanie listy Pythona za pomocą funkcji sorted().
W tym przykładzie zastosowaliśmy sortowanie według Lista Pythona .
Python3
okrągła matematyka Java
x>=> [>2>,>8>,>1>,>4>,>6>,>3>,>7>]> > print>(>'Sorted List returned :'>,>sorted>(x))> > print>(>'Reverse sort :'>,>sorted>(x, reverse>=>True>))> > print>(>'
Original list not modified :'>, x)> |
>
>Wyjście
ciąg porównaj Java
Sorted List returned : [1, 2, 3, 4, 6, 7, 8] Reverse sort : [8, 7, 6, 4, 3, 2, 1] Original list not modified : [2, 8, 1, 4, 6, 3, 7]>
2. Sortowanie różnych typów danych za pomocą funkcji sorted().
W tym przykładzie użyliśmy sorted() dla różnych typów danych, takich jak lista, krotka , strunowy, słownik , zestaw i zestaw zamrożony.
Python3
# List> x>=> [>'q'>,>'w'>,>'r'>,>'e'>,>'t'>,>'y'>]> print>(>sorted>(x))> > # Tuple> x>=> (>'q'>,>'w'>,>'e'>,>'r'>,>'t'>,>'y'>)> print>(>sorted>(x))> > # String-sorted based on ASCII translations> x>=> 'python'> print>(>sorted>(x))> > # Dictionary> x>=> {>'q'>:>1>,>'w'>:>2>,>'e'>:>3>,>'r'>:>4>,>'t'>:>5>,>'y'>:>6>}> print>(>sorted>(x))> > # Set> x>=> {>'q'>,>'w'>,>'e'>,>'r'>,>'t'>,>'y'>}> print>(>sorted>(x))> > # Frozen Set> x>=> frozenset>((>'q'>,>'w'>,>'e'>,>'r'>,>'t'>,>'y'>))> print>(>sorted>(x))> |
>
>Wyjście
['e', 'q', 'r', 't', 'w', 'y'] ['e', 'q', 'r', 't', 'w', 'y'] ['h', 'n', 'o', 'p', 't', 'y'] ['e', 'q', 'r', 't', 'w', 'y'] ['e', 'q', 'r', 't', 'w', 'y'] ['e', 'q', 'r', 't', 'w', 'y']>
3. Sortowanie odwrotne za pomocą Pythona sorted()
Sortowanie ciągu w odwrotnej kolejności leksykograficznej poprzez ustawienie odwrotna = prawda w funkcji sorted().
Python3
# Python3 code to demonstrate> # Reverse Sort a String> # using join() + sorted() + reverse> > # initializing string> test_string>=> 'geekforgeeks'> > # printing original string> print>(>'The original string : '> +> str>(test_string))> > # using join() + sorted() + reverse> # Sorting a string> res>=> ''.join(>sorted>(test_string, reverse>=> True>))> > # print result> print>(>'String after reverse sorting : '> +> str>(res))> |
>
>Wyjście
The original string : geekforgeeks String after reverse sorting : srokkggfeeee>
4. Python Sorted() z lambdą
Używanie sorted() wewnątrz funkcji lambda Pythona.
Python3
import> functools> test_string>=> 'geekforgeeks'> > print>(>'The original string : '> +> str>(test_string))> # using sorted() + reduce() + lambda> res>=> functools.>reduce>(>lambda> x, y: x>+> y,> >sorted>(test_string,> >reverse>=>True>))> print>(>'String after reverse sorting : '> +> str>(res))> |
>
>Wyjście
The original string : geekforgeeks String after reverse sorting : srokkggfeeee>
5. Sorted() w Pythonie za pomocą len()
W tym przykładzie sortujemy listę na podstawie jej długości. Na początek powinien znaleźć się sznurek o najmniejszej długości.
Python3
co to jest maven
L>=> [>'cccc'>,>'b'>,>'dd'>,>'aaa'>]> print>(>'Normal sort :'>,>sorted>(L))> print>(>'Sort with len :'>,>sorted>(L, key>=>len>))> |
>
>Wyjście
Normal sort : ['aaa', 'b', 'cccc', 'dd'] Sort with len : ['b', 'dd', 'aaa', 'cccc']>
Klucz może również przyjmować funkcje zdefiniowane przez użytkownika jako swoją wartość na podstawie sortowania.
Przykład:
Python3
# Sort a list of integers based on> # their remainder on dividing from 7> def> func(x):> >return> x>%> 7> > L>=> [>15>,>3>,>11>,>7>]> > print>(>'Normal sort :'>,>sorted>(L))> print>(>'Sorted with key:'>,>sorted>(L, key>=>func))> |
>
>Wyjście
Normal sort : [3, 7, 11, 15] Sorted with key: [7, 15, 3, 11]>
6. Sortowanie listy w kolejności rosnącej za pomocą sorted()
W my_list mamy listę wartości całkowitych. Następnie używamy funkcji sorted, aby posortować listę w kolejności rosnącej. Funkcja sortowana przyjmuje jako pierwszy argument iterowalną możliwość sortowania i zwraca nową listę zawierającą posortowane elementy.
W my_string mamy ciąg znaków. Następnie używamy funkcji sorted, aby posortować znaki w ciągu w kolejności rosnącej. Funkcja sortowana traktuje ciąg znaków jako iterowalną liczbę znaków i zwraca nową listę zawierającą posortowane znaki.
W my_tuples mamy listę krotek zawierającą liczby całkowite i ciągi znaków. Użyliśmy funkcji sorted, aby posortować listę na podstawie drugiego elementu każdej krotki. Aby to osiągnąć, przekazaliśmy funkcję lambda jako kluczowy argument funkcji posortowanej.
Python3
my_list>=> [>3>,>1>,>4>,>1>,>5>,>9>,>2>,>6>,>5>]> sorted_list>=> sorted>(my_list)> print>(sorted_list)> > my_string>=> 'hello, world!'> sorted_string>=> sorted>(my_string)> print>(sorted_string)> > my_tuples>=> [(>1>,>'one'>), (>3>,>'three'>), (>2>,>'two'>), (>4>,>'four'>)]> sorted_tuples>=> sorted>(my_tuples, key>=>lambda> x: x[>1>])> print>(sorted_tuples)> |
pseudokod Java
>
>Wyjście
[1, 1, 2, 3, 4, 5, 5, 6, 9] [' ', '!', ',', 'd', 'e', 'h', 'l', 'l', 'l', 'o', 'o', 'r', 'w'] [(4, 'four'), (1, 'one'), (3, 'three'), (2, 'two')]>
7. Sortowanie listy słowników według określonego klucza za pomocą sorted()
W tym przykładzie sortujemy listę słowników według określonego klucza.
Python3
students>=> [> >{>'name'>:>'John'>,>'age'>:>20>},> >{>'name'>:>'Alice'>,>'age'>:>18>},> >{>'name'>:>'Bob'>,>'age'>:>22>}> ]> sorted_students>=> sorted>(students,key>=>lambda> x: x[>'age'>])> print>(sorted_students)> |
>
>Wyjście
[{'name': 'Alice', 'age': 18}, {'name': 'John', 'age': 20}, {'name': 'Bob', 'age': 22}]> 8. Sortowanie listy obiektów niestandardowych
W tym przykładzie tworzymy niestandardową klasę o nazwie Person z dwiema zmiennymi instancji name i age oraz tworzymy trzy obiekty klasy Person i wstawiamy obiekty do list. Używamy funkcji Sorted, która sortuje obiekty Osoby.
Python3
class> Person:> >def> __init__(>self>, name, age):> >self>.name>=> name> >self>.age>=> age> > >def> __repr__(>self>):> >return> f>'Person(name='{self.name}', age={self.age})'> > > people>=> [> >Person(>'John'>,>25>),> >Person(>'Alice'>,>18>),> >Person(>'Bob'>,>30>)> ]> sorted_people>=> sorted>(people, key>=>lambda> x: x.age)> print>(sorted_people)> |
>
>Wyjście
[Person(name='Alice', age=18), Person(name='John', age=25), Person(name='Bob', age=30)]>
Omówiliśmy definicję, składnię i przykłady funkcji sorted() w Pythonie. Mam nadzieję, że to odpowiedziało na Twoje pytanie Jak używać funkcji posortowanej w Pythonie?.
Funkcji sorted() nie należy mylić z metodą listową sort(), ponieważ są one różne.
Mam nadzieję, że ten artykuł pomógł Ci w zrozumieniu funkcji sorted() w Pythonie.