Hướng dẫn sort() python

Hàm List sort[] trong Python sắp xếp các đối tượng của list. Nó sắp xếp các mục theo thứ tự giảm dần và tăng dần. Nó nhận một tham số tùy chọn 'reverse' để sắp xếp danh sách theo thứ tự giảm dần. Theo mặc định, các phần tử của list được sắp xếp theo thứ tự tăng dần.

Cú pháp

Cú pháp của sort[] trong Python:

Ví dụ sau minh họa cách sử dụng của sort[] để sắp xếp các phần tử của đối tượng list theo thứ tự tăng dần.

list1 = ['java', 'python', 'c++', 'php', 'sql']
list2 = [4, 2, 8, 10, 6]
list1.sort[]
list2.sort[]
print ["List1 duoc sap xep: ", list1]
print ["List2 duoc sap xep: ", list2]

Chạy chương trình Python trên sẽ cho kết quả:

List1 duoc sap xep:  ['c++', 'java', 'php', 'python', 'sql']
List2 duoc sap xep:  [2, 4, 6, 8, 10]

Ví dụ 2: hàm List sort[] trong Python

Ví dụ sau minh họa cách sử dụng của sort[] để sắp xếp các phần tử của đối tượng list theo thứ tự giảm dần.

list1 = ['java', 'python', 'c++', 'php', 'sql']
list2 = [4, 2, 8, 10, 6]
list1.sort[reverse=True]
list2.sort[reverse=True]
print ["List1 duoc sap xep: ", list1]
print ["List2 duoc sap xep: ", list2]

Chạy chương trình Python trên sẽ cho kết quả:

List1 duoc sap xep:  ['sql', 'python', 'php', 'java', 'c++']
List2 duoc sap xep:  [10, 8, 6, 4, 2]


Ví dụ 3: hàm List sort[] trong Python

Ví dụ sau minh họa cách sử dụng của sort[] để sắp xếp các phần tử char của đối tượng list theo thứ tự giảm dần.

list1 = ['a', 'p', 'p', 'l', 'e']
list1.sort[reverse=True]
print ["List1 duoc sap xep: ", list1]

Chạy chương trình Python trên sẽ cho kết quả:

List1 duoc sap xep:  ['p', 'p', 'l', 'e', 'a']

Bạn có biết sau khi tạo xong một list, bạn có thể tự do sắp xếp phần tử trong list python theo thứ tự tăng dần hay giảm dần không? Hãy tìm hiểu cách sắp xếp phần tử trong list python thông qua bài học này nhé.

Để sắp xếp phần tử trong list python, chúng ta cần dùng phương thức sort[] hoặc là Hàm List sorted[] trong Python. Với hai cách này, chúng ta sẽ sắp xếp trực tiếp giá trị của các phần tử trong list theo thứ tự tăng dần hoặc giảm dần.
Ngoài ra, bạn cũng có thể dùng giá trị của các phần tử này như là một đối số cho một hàm số trung gian, sau đó lấy giá trị thu về để tiến hành sắp xếp phần tử bằng cách sử dụng tham số sorted key python trong hàm sorted[].

Sắp xếp phần tử trong list python theo thứ tự tăng dần

Sắp xếp phần tử trong list theo thứ tự tăng dần | Hàm List sorted[] trong Python

Chúng ta sắp xếp phần tử trong list theo thứ tự tăng dần bằng hàm List sorted[] trong Python với cú pháp sau đây:

list_mới = sorted [ list_cũ , * , key = None, reverse = False ]

Bạn cũng có thể lược bỏ đi phần lớn đối số và chỉ dùng đối số list_cũ như cú pháp sau đây. Thực tế đây cũng là cách viết được sử dụng thông dụng nhất.

list_mới = sorted [ list_cũ]

Lại nữa, chúng ta cũng có thể dùng hàm sorted[] không những với list, mà còn với các iterable khác như chuỗi ký tự, tuple v.v… Do dó bạn cũng có thể thay thế đối số list_cũ bằng chuỗi_cũ hoặc tuple_cũ hay bất cứ dạng dữ liệu nào có chứa phần tử mà bạn cần sắp xếp.

Điều duy nhất cần chú ý là, bản thân đối số bạn chỉ định không thay đổi, list thì vẫn là list, tuple thì vẫn là tuple, chuỗi thì vẫn là chuỗi. Nhưng kết quả trả về sẽ luôn là một list mới. Cần chú ý nhé, không lại thắc mắc vì sao đưa một chuỗi ký tự đi sắp xếp mà kết quả trả về lại thành ra là list.

Để dễ hiểu hơn, hãy xem ví dụ sau đây, chúng ta sẽ sử dụng hàm sorted[] trong python như sau:

list_cũ = ["C", "A", "B"]
list_mới = sorted[list_cũ]

print[list_cũ]


print[list_mới]

Bạn có thể thấy, một list mới đã được tạo ra từ list_cũ với các phần tử được xắp xếp lại theo thứ tự tăng dần rồi phải không?

Sắp xếp phần tử trong list theo thứ tự tăng dần | phương thức sort[]

Chúng ta cũng có thể sắp xếp phần tử trong list python theo thứ tự tăng dần bằng phương thức sort[] với cú pháp đơn giản như dưới đây.

list.sort[]

Phương thức sort[] trong python sẽ sắp xếp lại phần tử trong chính list ban đầu theo thứ tự ban đầu. Lưu ý là bản thân list ban đầu được sắp xếp lại, chứ không có list mới nào được tạo ra.

Ví dụ cụ thể :

mylist = ["C", "A", "B"]
mylist.sort[]

print[mylist]

Sự khác biệt giữa sorted[list] vs list.sort[] trong python

Mặc dù chúng ta đều sử dụng sorted[list] lẫn list.sort[] để sắp xếp phần tử trong list theo thứ tự tăng dần, tuy nhiên hai phương pháp này có điểm khác biệt cực kỳ lớn đó là :

  • Hàm sorted[] không thay đổi list ban đầu mà tạo ra một list mới được sắp xếp lại từ list ban đầu.
  • Phương thức sort[] không tạo ra list mới mà chỉ sắp xếp lại chính list ban đầu.

Cũng cần phải lưu ý thêm nữa, vốn dĩ khái niệm hàmphương thức cũng đã khác nhau về bản chất, cách sử dụng rồi.

Tóm lại, bạn dùng hàm sorted[] khi cần tạo ra một list mới. Ngược lại trong trường hợp không cần tạo một list mới, thì bạn sẽ dùng phương thức sort[] để xắp xếp phần tử trong list python.

Sau đây chúng ta sẽ so sánh list.sort[] với sorted[list] trong python bằng các ví dụ cụ thể nhé:

Sắp xếp một list có phần tử là số:


numlist = [84, 75, 92, 90, 78]
newnumlist = sorted[numlist]
print[newnumlist]



numlist = [84, 75, 92, 90, 78]
numlist.sort[]
print[numlist]

Sắp xếp một list có phần tử là chữ:


colorlist = ["Blue", "Red", "Green", "White", "Black"]
newwcolor = sorted[colorlist]
print[newwcolor]



colorlist = ["Blue", "Red", "Green", "White", "Black"]
colorlist.sort[]
print[colorlist]

Sắp xếp phần tử trong list python theo thứ tự giảm dần

Theo mặc định thì hàm sorted[] hay phương thức sort[] sẽ sắp xếp list theo thứ tự tăng dần. Do đó nếu bạn muốn sắp xếp phần tử trong list python theo thứ tự tăng dần, thì bạn viết hàm và phương thức theo mặc định như Kiyoshi đã hướng dẫn ở phần trên.

Ngược lại nếu bạn muốn sắp xếp phần tử trong list python theo thứ tự giảm dần, hãy chỉ định thêm đối số reverse = True trong hàm sorted[] với cú pháp sau :

list_mới = sorted [ list_cũ , reverse = True]

Sự khác biệt ở đây là chúng ta cần chỉ định giá trị của reverse từ mặc định False thành True.
Hãy cùng xem các ví dụ sắp xếp phần tử trong list python theo thứ tự giảm dần sau đây:

mylist = ["C", "A", "B"]


newlist = sorted[mylist]
print[newlist]



newlist = sorted[mylist, reverse=False]
print[newlist]



newlist = sorted[mylist, reverse=True]
print[newlist]

Hãy thử một ví dụ khác phức tạp hơn:

colorlist = ["Blue", "Red", "Green", "White", "Black"]

asc_colorlist = sorted[colorlist]
desc_colorlist = sorted[colorlist, reverse=True]

print["list ban đầu:", colorlist]

print["tăng dần: ", asc_colorlist]

print["giảm :", desc_colorlist]

Sắp xếp phần tử trong list python chứa các phần tử có kiểu dữ liệu khác nhau

Ở phần trên, chúng ta đã học cách sắp xếp các phần tử trong list python, nếu list đó chỉ gồm toàn các phần tử giống nhau, như toàn là số, hoặc chuỗi ký tự rồi. Vậy khi kiểu dữ liệu của các phần tử trong list khác nhau, chúng ta cần làm thế nào?

Câu trả lời ở đây là, nếu các phần tử trong list khác kiểu dữ liệu nhưng vẫn so sánh được, thì chúng ta có thể sắp xếp list như bình thường với hàm sorted[] hoặc phương thức sort[]. Ví dụ như bạn muốn sắp xếp số nguyên với số thực hay số phức chẳng hạn. Giống như ví dụ sau đây:


numlist = [5, 3.14, 4,78, 4]

newnumlist = sorted [numlist]
print [newnumlist]

Nhưng nếu bạn muốn sắp xếp một list gồm các phần tử có kiểu dữ liệu khác nhau và chúng cũng không thể so sánh với nhau, ví dụ như chữ số và số chẳng hạn, thì nếu bạn dùng hàm sorted[] thì lỗi TypeError sẽ xảy ra như dưới đây:

mylist = ["80", 75, 45, "68"]
newmylist = sorted[mylist]

Kết quả trả về lỗi:

Traceback [most recent call last]:
File "Main.py", line 2, in
newmylist = sorted[mylist]
TypeError: '

Chủ Đề