Heim >Backend-Entwicklung >Python-Tutorial >Wie initialisiere ich ein Wörterbuch leerer Listen in Python richtig?
Ansätze zur Initialisierung eines Wörterbuchs leerer Listen in Python
Das Erstellen eines Wörterbuchs leerer Listen in Python kann mit verschiedenen Methoden erreicht werden. Wenn jedoch versucht wird, die Methode dict.fromkeys() zu verwenden, kann es zu einem Problem kommen, bei dem durch die Aktualisierung eines einzelnen Schlüssels auch alle anderen Schlüssel im Wörterbuch geändert werden.
Verstehen von dict.fromkeys( ) Methode
Die Methode dict.fromkeys() in Python initialisiert ein neues Wörterbuch mit den durch das erste Argument angegebenen Schlüsseln. Der jedem Schlüssel zugeordnete Wert ist das zweite Argument, dessen Standardwert „Keine“ ist. Wenn als zweites Argument eine leere Liste [] angegeben wird, verweisen alle Werte im resultierenden Wörterbuch auf dasselbe Listenobjekt. Dieses Verhalten führt zu dem in der Frage erwähnten unerwarteten Ergebnis.
Alternative Methoden zur Initialisierung
Um das oben genannte Problem zu vermeiden, können alternative Ansätze verwendet werden:
1. Dict Comprehension (Python 2.7 und höher)
data = {key: [] for key in range(2)}
Dieser Ansatz verwendet ein Wörterbuchverständnis, um ein neues Wörterbuch zu erstellen, in dem jeder Schlüssel einer leeren Liste zugeordnet ist.
2. Listenverständnis (Python 2.4-2.6)
data = dict([(key, []) for key in range(2)])
In diesem Fall wird ein Listenverständnis verwendet, um eine Liste von Tupeln zu generieren, wobei jedes Tupel aus einem Schlüssel und einer leeren Liste besteht. Die Liste der Tupel wird dann an den dict-Konstruktor übergeben, um das Wörterbuch zu erstellen.
3. Generatorausdruck (Python 2.4-2.6)
data = dict((key, []) for key in range(2))
Ähnlich wie beim Listenverständnisansatz kann ein Generatorausdruck direkt im Dict-Konstruktor verwendet werden, sodass keine umgebenden Klammern erforderlich sind.
Das obige ist der detaillierte Inhalt vonWie initialisiere ich ein Wörterbuch leerer Listen in Python richtig?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!