Funkcja sortowana() w Pythonie

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




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

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




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

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.