logo

Com ordenar un conjunt de valors a Python?

Ordenar significa ordenar el conjunt de valors de manera creixent o decreixent. Hi ha diversos mètodes per ordenar valors a Python. Podem emmagatzemar un conjunt o grup de valors utilitzant diverses estructures de dades com ara llista, tuples, diccionaris que depèn de les dades que estem emmagatzemant. Per tant, en aquest article, parlarem d'alguns mètodes i criteris per ordenar les dades a Python.

Mètode Sorted().

Aquest és un mètode predefinit a Python que ordena qualsevol tipus d'objecte.



Sintaxi:

sorted(iterable, key, reverse)>

En aquest mètode, passem 3 paràmetres, dels quals 2 (clau i invers) són opcionals i el primer paràmetre, és a dir, iterable pot ser qualsevol objecte iterable. Aquest mètode retorna una llista ordenada però no canvia l'estructura de dades original.

Exemple 1:



Python 3






# List> list_of_items>=> [>'g'>,>'e'>,>'e'>,>'k'>,>'s'>]> print>(>sorted>(list_of_items))> # Tuple> tuple_of_items>=> (>'g'>,>'e'>,>'e'>,>'k'>,>'s'>)> print>(>sorted>(tuple_of_items))> # String-sorted based on ASCII> # translations> string>=> 'geeks'> print>(>sorted>(string))> # Dictionary> dictionary>=> {>'g'>:>1>,>'e'>:>2>,>'k'>:>3>,>'s'>:>4>}> print>(>sorted>(dictionary))> # Set> set_of_values>=> {>'g'>,>'e'>,>'e'>,>'k'>,>'s'>}> print>(>sorted>(set_of_values))> # Frozen Set> frozen_set>=> frozenset>((>'g'>,>'e'>,>'e'>,>'k'>,>'s'>))> print>(>sorted>(frozen_set))>

>

quina és la mida del meu monitor

>


Sortida

['e', 'e', 'g', 'k', 's'] ['e', 'e', 'g', 'k', 's'] ['e', 'e', 'g', 'k', 's'] ['e', 'g', 'k', 's'] ['e', 'g', 'k', 's'] ['e', 'g', 'k', 's']>

Exemple 2:

Utilitzant una funció predefinida com a paràmetre clau. Així que el segon paràmetre és a dir. clau s'utilitza per ordenar l'estructura de dades donada per alguna funció predefinida, com ara només () o alguna funció definida per l'usuari. Ordena els valors de l'estructura de dades en funció de la funció passat al paràmetre clau.

Python 3




# using key parameter with pre-defined> # function i.e. len()> list_of_items>=> [>'apple'>,>'ball'>,>'cat'>,>'dog'>]> print>(>'Sorting without key parameter:'>,>sorted>(list_of_items))> print>(>'Sorting with len as key parameter:'>,>sorted>(list_of_items, key>=>len>))>

>

>

Sortida

Sorting without key parameter: ['apple', 'ball', 'cat', 'dog'] Sorting with len as key parameter: ['cat', 'dog', 'ball', 'apple']>

Exemple 3:

Ús de la funció definida per l'usuari per al paràmetre clau.

Python 3




# using key parameter with user-defined> # function i.e. by_name> # using key parameter with user-defined> # function i.e. by_marks> # here is a list_of_tuples where the first> # item in tuple is the student name and the> # second item is his/her marks> list_of_items>=> [(>'Ramesh'>,>56>),(>'Reka'>,>54>),(>'Lasya'>,>32>),(>'Amar'>,>89>)]> # defining a user-defined function which returns> # the first item(name)> def> by_name(ele):> >return> ele[>0>]> # defining a user-defined function which returns> # the second item(marks)> def> by_marks(ele):> >return> ele[>1>]> print>(>'Sorting without key parameter:'>,>sorted>(list_of_items))> print>(>'Sorting with by_name as key parameter:'>,> >sorted>(list_of_items, key>=>by_name))> print>(>'Sorting with by_marks as key parameter:'>,> >sorted>(list_of_items, key>=>by_marks))>

>

>

Sortida

Classificació sense paràmetre clau: [('Amar', 89), ('Lasya', 32), ('Ramesh', 56), ('Reka', 54)]

Ordenant amb by_name com a paràmetre clau: [('Amar', 89), ('Lasya', 32), ('Ramesh', 56), ('Reka', 54)]

Ordenant amb by_marks com a paràmetre clau: [('Lasya', 32), ('Reka', 54), ('Ramesh', 56), ('Amar', 89)]

Exemple 4:

Doncs el El tercer paràmetre és invers que s'utilitza per ordenar l'iterable en ordre descendent o decreixent.

Python 3

Expressions java lambda




# using key parameter reverse> list_of_items>=> [>'geeks'>,>'for'>,>'geeks'>]> print>(>'Sorting without key parameter:'>,> >sorted>(list_of_items))> print>(>'Sorting with len as key parameter:'>,> >sorted>(list_of_items, reverse>=>True>))>

>

>

Sortida

Sorting without key parameter: ['for', 'geeks', 'geeks'] Sorting with len as key parameter: ['geeks', 'geeks', 'for']>

Exemple 5:

Utilitzant els tres paràmetres

Python 3


on és la configuració del navegador



# using by_name and by_marks as key parameter> # and making reverse parameter true> # here is a list_of_tuples where the first> # item in tuple is the student name and the> # second item is his/her marks> list_of_items>=> [(>'Ramesh'>,>56>), (>'Reka'>,>54>),> >(>'Lasya'>,>32>), (>'Amar'>,>89>)]> # defining a user-defined function which> # returns the first item(name)> def> by_name(ele):> >return> ele[>0>]> # defining a user-defined function which> # returns the second item(marks)> def> by_marks(ele):> >return> ele[>1>]> print>(>'Sorting without key and reverse:'>,>sorted>(list_of_items))> print>(>'Sorting with by_name as key parameter and reverse parameter as False:'>,> >sorted>(list_of_items, key>=>by_name, reverse>=>False>))> print>(>'Sorting with by_name as key parameter and reverse parameter as True:'>,> >sorted>(list_of_items, key>=>by_name, reverse>=>True>))> print>(>'Sorting with by_marks as key parameter and reverse parameter as False:'>,> >sorted>(list_of_items, key>=>by_marks, reverse>=>False>))> print>(>'Sorting with by_marks as key parameter and reverse parameter as True:'>,> >sorted>(list_of_items, key>=>by_marks, reverse>=>True>))>

>

>

Sortida

Ordenant sense clau i invers: [(‘Amar’, 89), (‘Lasya’, 32), (‘Ramesh’, 56), (‘Reka’, 54)]

Ordenant amb by_name com a paràmetre clau i el paràmetre invers com a Fals: [('Amar', 89), ('Lasya', 32), ('Ramesh', 56), ('Reka', 54)]

Ordenant amb by_name com a paràmetre clau i el paràmetre invers com a True: [('Reka', 54), ('Ramesh', 56), ('Lasya', 32), ('Amar', 89)]

Ordenant amb by_marks com a paràmetre clau i el paràmetre invers com a Fals: [(‘Lasya’, 32), (‘Reka’, 54), (‘Ramesh’, 56), (‘Amar’, 89)]

Ordenant amb by_marks com a paràmetre clau i el paràmetre invers com a True: [('Amar', 89), ('Ramesh', 56), ('Reka', 54), ('Lasya', 32)]

Mètode Sort().

Aquest mètode ordena la llista en ordre ascendent per defecte, i podem utilitzar el paràmetre invers per ordenar en ordre descendent. Aquest mètode canvia la llista original i no retorna res.

Exemple 1:

Python 3




Heapify sort
# creating a list of items> list_of_items>=> [>'geeks'>,>'for'>,>'geeks'>]> print>(>'Original list:'>, list_of_items)> # using the sort method to sort> # the items> list_of_items.sort()> # displaying the list> print>(>'Sorted list:'>, list_of_items)>

>

>

Sortida

Original list: ['geeks', 'for', 'geeks'] Sorted list: ['for', 'geeks', 'geeks']>

Exemple 2:

Utilitzant una funció predefinida com a paràmetre clau

Python 3




# using key parameter with pre-defined> # function i.e. len()> list_of_items>=> [>'apple'>,>'ball'>,>'cat'>,>'dog'>]> print>(>'Original List:'>, list_of_items)> # using the len() as key parameter and> # sorting the list> list_of_items.sort(key>=>len>)> print>(>'Sorting with len as key parameter:'>, list_of_items)>

>

>

Sortida

Original List: ['apple', 'ball', 'cat', 'dog'] Sorting with len as key parameter: ['cat', 'dog', 'ball', 'apple']>

Exemple 3:

Utilitzant una funció definida per l'usuari com a paràmetre clau

Python 3




# using key parameter with user-defined> # function i.e. by_name> # using key parameter with user-defined> # function i.e. by_marks> # defining a user-defined function which> # returns the first item(name)> def> by_name(ele):> >return> ele[>0>]> # defining a user-defined function which> # returns the second item(marks)> def> by_marks(ele):> >return> ele[>1>]> # here is a list_of_tuples where the first> # item in tuple is the student name and the> # second item is his/her marks> list_of_items>=> [(>'Ramesh'>,>56>), (>'Reka'>,>54>),> >(>'Lasya'>,>32>), (>'Amar'>,>89>)]> print>(>'original list:'>, list_of_items)> # sorting by key value as by_name function> list_of_items.sort(key>=>by_name)> print>(>'Sorting with by_name as key parameter:'>, list_of_items)> # here is a list_of_tuples where the first> # item in tuple is the student name and the> # second item is his/her marks> list_of_items>=> [(>'Ramesh'>,>56>), (>'Reka'>,>54>),> >(>'Lasya'>,>32>), (>'Amar'>,>89>)]> print>(>'original list:'>, list_of_items)> # sorting by key value as by_marks function> list_of_items.sort(key>=>by_marks)> print>(>'Sorting with by_marks as key parameter:'>, list_of_items)>

>

>

Sortida

llista original: [(‘Ramesh’, 56), (‘Reka’, 54), (‘Lasya’, 32), (‘Amar’, 89)]

Ordenant amb by_name com a paràmetre clau: [('Amar', 89), ('Lasya', 32), ('Ramesh', 56), ('Reka', 54)]

llista original: [(‘Ramesh’, 56), (‘Reka’, 54), (‘Lasya’, 32), (‘Amar’, 89)]

Ordenant amb by_marks com a paràmetre clau: [('Lasya', 32), ('Reka', 54), ('Ramesh', 56), ('Amar', 89)]

Exemple 4:

Utilitzant el paràmetre invers

Python 3


a b c nombres



# using key parameter reverse> list_of_items>=> [>'geeks'>,>'for'>,>'geeks'>]> print>(>'original list:'>, list_of_items)> list_of_items.sort(reverse>=>True>)> print>(>'sorting with reverse parameter'>, list_of_items)>

>

>

Sortida

original list: ['geeks', 'for', 'geeks'] sorting with reverse parameter ['geeks', 'geeks', 'for']>