logo

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




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.