Sắp xếp danh sách trong từ điển python

Trong bài viết này, chúng ta sẽ xem cách sắp xếp danh sách từ điển bằng các giá trị. Từ điển đại diện cho cặp khóa-giá trị trong Python, được đặt trong dấu ngoặc nhọn. Các khóa là duy nhất và dấu hai chấm phân tách nó khỏi giá trị, trong khi dấu phẩy phân tách các mục. Cùng với đó, kích thước bên trái trước dấu hai chấm là các khóa, trong khi bên phải là các giá trị tương ứng của nó

Giả sử chúng ta có danh sách Từ điển sau đây -

[{'name': 'Sam', 'marks': 98}, {'name': 'Tom', 'marks': 93}, {'name': 'Jacob', 'marks': 97}]

Đầu ra phải như sau -

Sorted =
[{'name': 'Tom', 'marks': 93}, {'name': 'Jacob', 'marks': 97}, {'name': 'Sam', 'marks': 98}]

Sắp xếp Danh sách Từ điển sử dụng các giá trị với hàm lambda trong phương thức sorted[] theo thứ tự Giảm dần

Trong hướng dẫn này, chúng tôi xem xét các phương pháp khác nhau để sắp xếp từ điển theo giá trị trong Python. Chúng tôi sẽ hiểu lý do tại sao nó được yêu cầu và làm thế nào để làm như vậy

Mục lục - Python sắp xếp từ điển theo giá trị

  • Tại sao chúng ta cần sắp xếp từ điển Python?
  • Các phương pháp khác nhau để sắp xếp từ điển theo giá trị trong Python
    • Bằng cách chuyển đổi dữ liệu trong từ điển sang danh sách
      • Sử dụng Sắp xếp bong bóng
      • Sử dụng phương thức sorted[]
      • Sử dụng Phương thức itemgetter[]
      • sử dụng chính tả. Các hàm item[] và sorted[]
    • Bằng cách thực hiện các thao tác trực tiếp trên từ điển
      • Sử dụng vòng lặp for
      • Sử dụng hàm sorted[]
      • Sử dụng Hàm Lambda
      • Sử dụng từ điển. item[] Phương thức
  • Bớt tư tưởng

Tại sao chúng ta cần sắp xếp từ điển Python theo giá trị?

Trong Python, từ điển lưu trữ dữ liệu không có thứ tự chứa "key. value" được phân tách bằng dấu phẩy bên trong dấu ngoặc nhọn. Lớp từ điển Python không cho phép sắp xếp để sắp xếp các mục trong đối tượng của nó. Chúng tôi có thể truy xuất các giá trị khi khóa tồn tại và được biết

Hãy xem xét một lượng dữ liệu khổng lồ trong từ điển Python. Trong trường hợp này, để giảm độ phức tạp của việc thu thập dữ liệu bằng cách sắp xếp dữ liệu sẽ dẫn đến kết quả nhanh chóng. Do đó, để tiết kiệm thời gian và tăng hiệu quả đối với dữ liệu lớn, chẳng hạn như danh bạ, chúng ta cần sắp xếp từ điển Python

Chúng ta có thể sắp xếp từ điển bằng danh sách và thực hiện sắp xếp trên danh sách. Hãy để chúng tôi xem những cách khác nhau để làm điều này

Các phương pháp khác nhau để sắp xếp từ điển theo giá trị trong Python

Bằng cách chuyển đổi dữ liệu trong từ điển sang danh sách

Trước tiên chúng ta sẽ xem xét cách chuyển đổi dữ liệu trong từ điển thành danh sách. Sau đó, chúng tôi thực hiện sắp xếp danh sách để sắp xếp từ điển Python

Thí dụ-

markdict={"Tom":67, "Tina": 54, "Akbar": 87, "Kane": 43, "Divya":73}
marklist=list[markdict.items[]]
print[marklist]

Đầu ra-

[['Tom', 67], ['Tina', 54], ['Akbar', 87], ['Kane', 43], ['Divya', 73]]

Ở đây, chúng tôi đang chuyển đổi từ điển thành danh sách bằng cách sử dụng hàm list[]. Khi danh sách đã sẵn sàng, chúng ta có thể thực hiện các thao tác trên nó để có được kết quả mong muốn trên từ điển

Sử dụng Sắp xếp bong bóng

Thí dụ -

markdict={"Tom":67, "Tina": 54, "Akbar": 87, "Kane": 43, "Divya":73}
l=len[marklist]
  for i in range[l-1]:
    for j in range[i+1,l]:
      if marklist[i][1]>marklist[j][1]:
            t=marklist[i]
            marklist[i]=marklist[j]
            marklist[j]=t
    sortdict=dict[marklist]print[sortdict]

Đầu ra-

{'Kane': 43, 'Tina': 54, 'Tom': 67, 'Divya': 73, 'Akbar': 87}

Trong ví dụ này, chúng tôi sử dụng Sắp xếp bong bóng đơn giản bằng cách sử dụng biến tạm thời t và sắp xếp các giá trị trong danh sách

Sử dụng phương thức sorted[]

Hàm sorted[] trong Python trả về danh sách đã sắp xếp từ các lần lặp đã chỉ định và trả về danh sách các mục đã sắp xếp

Cú pháp-

sorted [iterable, key, reverse]

Thí dụ-

marklist = sorted[markdict.items[], key=lambda x:x[1]]
sortdict = dict[marklist]
print[sortdict]

Đầu ra-

________số 8

Ở đây, trong hàm sorted[], iterable là markdict. các mục và khóa được đặt là lambda x. x[1]. Sau khi sắp xếp các mục, chúng tôi tạo một sortdict từ điển mới để gọi dữ liệu được sắp xếp

Sử dụng Phương thức itemgetter[]

Trong Python, hàm itemgetter[] trả về một đối tượng có thể gọi được từ toán hạng của nó. Sử dụng hàm itemgetter[] với hàm sorted[] sẽ trả về các mục được sắp xếp trong từ điển theo giá trị

Thí dụ-

import operator

markdict = {"Tom":67, "Tina": 54, "Akbar": 87, "Kane": 43, "Divya":73}
marklist= sorted[markdict.items[], key=operator.itemgetter[1]] 
sortdict=dict[marklist]
print[sortdict]

Đầu ra-

________số 8

người điều hành. Hàm itemgetter[item] trả về một đối tượng có thể gọi được để tìm nạp mục từ toán hạng của nó bằng cách sử dụng phương thức __getitem__[] của toán hạng

sử dụng chính tả. Các hàm item[] và sorted[]

mệnh lệnh. Phương thức items[] và hàm sorted[] có thể được sử dụng cùng nhau để trả về danh sách các mục được sắp xếp theo giá trị trong từ điển

Thí dụ-

Sorted =
[{'name': 'Tom', 'marks': 93}, {'name': 'Jacob', 'marks': 97}, {'name': 'Sam', 'marks': 98}]
1

Đầu ra-

________số 8

Trong ví dụ trên, chúng ta sắp xếp từ điển bằng hàm sorted[] và tạo một bộ sắp xếp từ điển mới với các giá trị được sắp xếp

Bằng cách thực hiện các thao tác trực tiếp trên từ điển

Từ điển Python cũng có thể được sắp xếp mà không cần chuyển đổi các mục thành danh sách. Dưới đây là những cách để làm điều đó

Sử dụng vòng lặp for 

Bằng cách sử dụng vòng lặp for cùng với hàm sorted[] trong Python, chúng ta có thể sắp xếp từ điển theo giá trị. Đây là một ví dụ cho cùng

Thí dụ-

[['Tom', 67], ['Tina', 54], ['Akbar', 87], ['Kane', 43], ['Divya', 73]]
1

Đầu ra-

________số 8

Ở đây, đầu tiên chúng ta sử dụng hàm sort[] để sắp xếp thứ tự các giá trị của từ điển. Hàm sorted[] không sắp xếp lại từ điển tại chỗ, do đó, chúng tôi lưu trữ giá trị của nó trong sorted_values. Sau đó, chúng tôi lặp qua các giá trị đã sắp xếp, tìm khóa cho từng giá trị. Điều này cuối cùng đã được thêm vào từ điển mới sorted_dict[k]

Sử dụng Hàm sắp xếp[]

Thí dụ-

[['Tom', 67], ['Tina', 54], ['Akbar', 87], ['Kane', 43], ['Divya', 73]]
3

Đầu ra-

________số 8

Trong ví dụ này, chúng tôi sử dụng phím chức năng trên từng phần tử trước khi so sánh các giá trị để sắp xếp. Một chức năng khác được sử dụng ở đây là get[] để trả về các giá trị tương ứng với khóa của từ điển. Như vậy, hàm sorted[dict1, key=dict1. get] trả về danh sách các khóa có giá trị được sắp xếp

Sử dụng Hàm Lambda

Chúng ta có thể sử dụng hàm Python sorted[] với hàm lambda để sắp xếp từ điển theo giá trị. Cú pháp của hàm lambda như sau

Cú pháp-

[['Tom', 67], ['Tina', 54], ['Akbar', 87], ['Kane', 43], ['Divya', 73]]
5

Thí dụ-

[['Tom', 67], ['Tina', 54], ['Akbar', 87], ['Kane', 43], ['Divya', 73]]
6

Đầu ra-

________số 8

Sử dụng từ điển. item[] Phương thức

Phương thức items[] có thể sắp xếp từ điển theo giá trị và trả về giá trị đã sắp xếp. Dưới đây là ví dụ về cách chúng ta có thể sử dụng phương pháp này

Thí dụ-

[['Tom', 67], ['Tina', 54], ['Akbar', 87], ['Kane', 43], ['Divya', 73]]
8

Đầu ra-

________số 8

Trong ví dụ này, chúng ta sử dụng hàm sorted[], set iterable là dictionary. items[] và key là key=itemgetter[1] để lấy các giá trị đã sắp xếp của từ điển

Bớt tư tưởng

Chúng ta có thể sắp xếp từ điển Python theo các giá trị theo hai cách. Một là bằng cách chuyển đổi dữ liệu từ điển thành danh sách và sau đó sắp xếp danh sách. Một cách khác là sắp xếp từ điển trực tiếp

Bạn có thể sử dụng sắp xếp trên từ điển trong Python không?

Chà, kể từ python 3. 7, từ điển cũng nhớ thứ tự các mục được chèn. Do đó chúng ta cũng có thể sắp xếp từ điển bằng cách sử dụng hàm sorted[] tích hợp sẵn của python . Cũng giống như các iterable khác, chúng ta có thể sắp xếp từ điển dựa trên các tiêu chí khác nhau tùy thuộc vào đối số chính của hàm sorted[].

Chúng ta có thể sắp xếp các phần tử trong từ điển không?

Hàm quan trọng mà bạn sẽ sử dụng để sắp xếp từ điển là hàm sorted[] được tích hợp sẵn. Hàm này lấy một đối số có thể lặp lại làm đối số chính, với hai đối số chỉ có từ khóa tùy chọn—một hàm khóa và một giá trị Boolean đảo ngược

Bạn có thể sắp xếp danh sách bằng Python không?

Phương thức sort[] là một trong những cách bạn có thể sắp xếp danh sách trong Python . Khi sử dụng sort[] , bạn sắp xếp một danh sách tại chỗ. Điều này có nghĩa là danh sách ban đầu được sửa đổi trực tiếp. Cụ thể, thứ tự ban đầu của các phần tử bị thay đổi.

Chủ Đề