Heim >Backend-Entwicklung >Python-Tutorial >Wie erhalte ich den nächsten Schlüssel in einem Wörterbuch in Python?

Wie erhalte ich den nächsten Schlüssel in einem Wörterbuch in Python?

王林
王林nach vorne
2023-08-28 23:45:121145Durchsuche

Wie erhalte ich den nächsten Schlüssel in einem Wörterbuch in Python?

Dictionary ist ein leistungsstarker Datentyp in Python. Es besteht aus Schlüssel-Wert-Paaren. Such-, Anhänge- und andere Vorgänge können mit diesem Datentyp effizient durchgeführt werden. Während der Zugriff auf Werte in einem Wörterbuch einfach ist, kann es Situationen geben, in denen Sie den nächsten Schlüssel im Wörterbuch nachschlagen müssen. Abhängig von Ihren spezifischen Anforderungen bietet Python mehrere Möglichkeiten, dies zu erreichen. In diesem Artikel werden wir verschiedene Möglichkeiten untersuchen, um den nächsten Schlüssel in einem Wörterbuch in Python abzurufen.

Verwenden Sie Schlüssel und Indexmethoden

Wörterbücher in Python sind ungeordnete Sammlungen. Daher müssen wir zunächst die Schlüssel in eine sortierte Form umwandeln. Wir können zunächst alle Schlüssel in Form einer Liste anhängen. Als nächstes können wir den nächsten Schlüssel finden, indem wir die Liste indizieren. Mit Hilfe von Schlüsseln können wir auch auf die entsprechenden Werte zugreifen.

Grammatik

<dictionary name>.keys()

Die Methode „keys“ ist eine in Python integrierte Methode, die die Schlüssel im Wörterbuch zurückgibt. Es gibt ein Ansichtsobjekt zurück, das wir mit der Listenmethode von Python in eine Liste konvertieren können. Das Ansichtsobjekt ist dynamisch, sodass alle Änderungen am Wörterbuch auch im Ansichtsobjekt widergespiegelt werden.

<iterable object>.index(<name of the key>, start, end)

In Python ist die Methode „index“ eine integrierte Methode. Es kann auf iterierbare Sequenzen angewendet werden. Es akzeptiert einen erforderlichen Parameter, nämlich den Wert, dessen Index wir in der iterierbaren Sequenz finden müssen. Darüber hinaus akzeptiert es zwei optionale Parameter, start und end, die den Bereich definieren, in dem wir Elemente finden müssen. Es gibt eine Ganzzahl zurück, die das erste Vorkommen des Elements in der iterierbaren Sequenz darstellt.

Beispiel

Im folgenden Code erstellen wir zunächst ein Wörterbuch mit dem Namen my_dict. Wir definieren den aktuellen Schlüssel als „Banane“. In diesem Fall besteht unser Ziel darin, den nächsten Schlüssel „orange“ zu finden. Wir verwenden die Schlüsselmethode des Wörterbuchs, um alle Wörterbuchschlüssel abzurufen. Als nächstes verwenden wir die Indexmethode, um auf den Index des aktuellen Schlüssels zuzugreifen. Wir stellen eine bedingte Anweisung bereit, in der wir Schlüssel ausgeben, deren Index nur um 1 größer als der aktuelle Schlüssel ist.

my_dict = {'apple': 1, 'banana': 2, 'orange': 3, 'kiwi': 4}
current_key = 'banana'
keys = list(my_dict.keys())
current_index = keys.index(current_key)
print("The next element to banana is: ", end="")
if current_index < len(keys) - 1:
    next_key = keys[current_index + 1]
    print(next_key)  
else:
    print("No next key found.")

Ausgabe

The next element to banana is − orange

Verwendung des OrderedDict-Moduls

Eine andere Möglichkeit, den nächsten Schlüssel im Wörterbuch abzurufen, besteht darin, die OrderedDict-Klasse aus dem Collections-Modul zu verwenden. OrderedDict ermöglicht es uns, ein Wörterbuch zu erstellen und seine Elemente zu durchlaufen. Bei Verwendung dieses Moduls unterscheidet sich die Wörterbuchdarstellung jedoch stark von der herkömmlicher Wörterbücher. Elemente werden als Tupel dargestellt.

Grammatik

OrderedDict([(key1, value1), (key2, value2), (key3, value3), other key-value pairs.....])

'OrderedDict' ist der Klassenname des geordneten Wörterbuchs, das vom Python-Modul 'collections' bereitgestellt wird. Wir müssen alle Schlüssel-Wert-Paare als Tupelobjekte übergeben, wobei die Tupelobjekte durch Kommas getrennt werden. Wir können mehrere Tupelobjekte haben, und dieses Wörterbuchobjekt ist iterierbar.

Beispiel

In diesem Code importieren wir zunächst das OrderedDict-Modul aus der Sammlungsbibliothek von Python. Als nächstes definieren wir unser Wörterbuch. Beachten Sie, dass Schlüssel-Wert-Paare durch Kommas getrennt und in Tupeln eingeschlossen sind. Dann setzen wir das Flag der Variablen „found_current_key“ auf „false“. Wir durchlaufen das Wörterbuch und aktualisieren den Wert der Variablen next_key. Diese Variable enthält das Ergebnis, das wir benötigen. Beachten Sie, dass wir OrderedDict verwendet haben, sodass das Wörterbuch jetzt iterierbar ist.

from collections import OrderedDict
my_dict = OrderedDict([('apple', 1), ('banana', 2), ('orange', 3), ('kiwi', 4)])
current_key = 'orange'
next_key = None
found_current_key = False
print("The next element to banana is: ", end="")
for key in my_dict:
    if found_current_key:
        next_key = key
        break
    if key == current_key:
        found_current_key = True
print(next_key)  

Ausgabe

The next element to banana is: kiwi

Verwenden Sie die Methode „keys()“ und die Flags

Wenn Sie die Reihenfolge der Schlüssel nicht beibehalten müssen, besteht ein einfacher Ansatz darin, die Methode „keys()“ des Wörterbuchs und eine Flag-Variable zu verwenden, um den aktuellen Schlüssel zu verfolgen. Die Idee besteht darin, die Wörterbuchschlüssel zu durchlaufen und, wenn der aktuelle Schlüssel gefunden wird, den Wert des nächsten Schlüssels zu aktualisieren. Bitte beachten Sie, dass wir bei Verwendung der Python-Methode „keys“ alle Schlüssel in Form einer Liste erhalten. Diese Listen sind iterierbar, sodass wir diese Iteration durchführen können.

Beispiel

Im folgenden Code erstellen wir das Wörterbuch und setzen den Wert von current_key auf „apple“. Als nächstes setzen wir den Wert der Variablen next_key auf False. Wir iterieren über die Schlüssel des Wörterbuchs. Wir haben bedingte Anweisungen verwendet. Die bedingte Anweisung prüft, ob das Flag „found_current_key“ wahr ist und weist in diesem Fall den aktuellen Schlüssel „next_key“ zu, wodurch die Schleife unterbrochen wird. Das Flag „found_current_key“ ist wahr, wenn der aktuelle Schlüssel gleich „current_key“ ist.

my_dict = {'apple': 1, 'banana': 2, 'orange': 3, 'kiwi': 4}
current_key = 'apple'
next_key = None
found_current_key = False
print("The next element to banana is: ", end="")
for key in my_dict.keys():
    if found_current_key:
        next_key = key
        break
    if key == current_key:
        found_current_key = True
print(next_key) 

Ausgabe

The next element to banana is: banana

Fazit

In diesem Artikel haben wir gelernt, wie man den nächsten Schlüssel in einem Wörterbuch in Python erhält. Wir können die Iterationseigenschaft von list oder tuple nutzen, um alle Wörterbuchschlüssel zu sammeln und den nächsten verfügbaren Schlüssel zu finden. Python stellt uns außerdem das Ordered Dict-Modul zur Verfügung, mit dem wir problemlos über Wörterbuchelemente iterieren können. Dieses Modul bietet uns die Möglichkeit, iterative Wörterbücher zu erstellen. Schließlich können wir Schlüssel und Flags verwenden, um denselben Zweck zu erreichen.

Das obige ist der detaillierte Inhalt vonWie erhalte ich den nächsten Schlüssel in einem Wörterbuch in Python?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Dieser Artikel ist reproduziert unter:tutorialspoint.com. Bei Verstößen wenden Sie sich bitte an admin@php.cn löschen