Kann jemand erklären, wie Python (v3.5)-Wörterbücher sortiert werden?
data = {"john": 23, "rick": 33, "mary": 63, "ron": 23, "joel": 51} for key in data: print("your name is " + key + ", and you are also " + str(data[key]) + " years old.")
Tatsächliche Ausgabe:
your name is rick, and you are also 33 years old. your name is ron, and you are also 23 years old. your name is mary, and you are also 63 years old. your name is john, and you are also 23 years old. your name is joel, and you are also 51 years old.
Erwartete Ausgabe (lexikografische Reihenfolge):
Your name is John, and you are also 23 years old. Your name is Rick, and you are also 33 years old. Your name is Mary, and you are also 63 years old. Your name is Ron, and you are also 23 years old. Your name is Joel, and you are also 51 years old.
Das hängt von der Python-Version ab, die Sie verwenden.
Das Wörterbuch verwendet zum Sortieren die zugrunde liegende Hash-Funktion. Einige Typen verfügen über gesalzene Hashes, sodass Sie bei jedem Aufruf eine andere Reihenfolge erhalten.
Wörterbücher sind in der Einfügereihenfolge angeordnet, d. h. das Wörterbuch merkt sich die Reihenfolge, in der Elemente eingefügt werden. Von Dokumente:
Guido van Rossum gab bekannt, dass alle Python-Implementierungen ab Python 3.7 die Einfügereihenfolge beibehalten müssen .
Das obige ist der detaillierte Inhalt vonDie Reihenfolge von Python-Wörterbüchern verstehen. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!