Rumah >pembangunan bahagian belakang >Tutorial Python >Bagaimanakah Saya Boleh Mencipta Koleksi Diisih, Disusun daripada Kamus Python?

Bagaimanakah Saya Boleh Mencipta Koleksi Diisih, Disusun daripada Kamus Python?

Barbara Streisand
Barbara Streisandasal
2024-12-28 22:28:16726semak imbas

How Can I Create a Sorted, Ordered Collection from a Python Dictionary?

Isih Kamus mengikut Kunci: Memperoleh Koleksi Tertib

Sifat intrinsik kamus Python adalah tidak tertib, kecuali pengenalan Python 3.7. Walaupun mengisih pasangan (kunci, nilai) mungkin muncul sebagai penyelesaian, adalah penting untuk mengakui bahawa mengekalkan susunan yang diisih semasa menyimpan semula elemen ke dalam kamus adalah tidak boleh dilaksanakan.

Untuk mewujudkan koleksi tersusun dengan lancar berdasarkan nilai utama, penggunaan kelas OrderedDict diutamakan sebagai pendekatan optimum. Kelas ini mempunyai keupayaan unik untuk mengekalkan urutan sisipan elemennya:

import collections

d = {2: 3, 1: 89, 4: 5, 3: 0}

# Construct an OrderedDict from sorted key-value pairs
od = collections.OrderedDict(sorted(d.items()))

print(od)  # OrderedDict([(1, 89), (2, 3), (3, 0), (4, 5)])

Walaupun perwakilan cetakan od mungkin berbeza-beza, ia akan mengekalkan susunan yang diingini semasa interaksi berikutnya:

print(od[1])  # 89
print(od[3])  # 0

for k, v in od.items():
    print(k, v)  # 1 89, 2 3, 3 0, 4 5

Pertimbangan untuk Python 3 Pengguna

Pengguna Python 3 harus menggunakan kaedah .items() dan bukannya .iteritems() apabila melelaran melalui OrderedDict untuk mengekalkan keserasian:

for k, v in od.items():
    print(k, v)  # 1 89, 2 3, 3 0, 4 5

Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Mencipta Koleksi Diisih, Disusun daripada Kamus Python?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn