Heim > Artikel > Backend-Entwicklung > Python implementiert variable Variablennamen
Dieser Artikel stellt hauptsächlich die Methode zur Verwendung dynamischer Variablennamen in Python vor. Freunde, die es benötigen, können sich auf
Wenn Sie schreiben möchten ein Programm, x1 sei 1, x2 sei 2, und was würden Sie dann tun, bis x100 100 ist?
In einer statischen Sprache wie C wird der Bezeichner des Variablennamens vom Compiler tatsächlich direkt in eine Speicheradresse übersetzt, daher gibt es keine Möglichkeit, dies zu tun, außer den Wert jeder Variablen manuell festzulegen. Und dynamische Sprachen wie Python können das.
Das einfachste, was man sich vorstellen kann, ist natürlich eval, aber tatsächlich besteht keine Notwendigkeit für so etwas Gefährliches, da der Variablenname von Python nur der Schlüssel eines Wörterbuchs ist. Um dieses Wörterbuch zu erhalten, verwenden Sie einfach direkt die Funktionen locals und globals.
Dieses Programm kann also folgendermaßen implementiert werden:
Der Code lautet wie folgt:
>>> names = locals() >>> for i in xrange(1, 101): ... names['x%s' % i] = i ... >>> x1 1 >>> x2 2 >>> x100 100
Aber man kann sagen, dass dieses Beispiel nutzlos ist, schließlich ist es mehr Praktisch ist die Verwendung eines Arrays zur Implementierung.
Dann betrachten Sie ein anderes Beispiel: Der Server verwendet eine Objektdatenbank und kann Objekte direkt in der Datenbank speichern. Der Server listet alle derzeit unterstützten Klassen auf und der Benutzer möchte eine Klasse hinzufügen, die nicht in der Liste vorhanden ist. Daher wird ein JSON- oder XML-Text an den Server gesendet. Der Server analysiert diesen Text, wandelt ihn in ein Klassenobjekt um und legt den Klassennamen fest. Der Benutzer kann dann beliebig Objekte dieser Klasse generieren.
Der Schlüssel ist, dass diese Datenbank mit dem Klassennamen zusammenhängt. Sie können nicht eine allgemeine Objektklasse verwenden, um alle Objekte zu speichern, da sonst die Abfrage durcheinander kommt.
Zufälligerweise hat jemand diese Anforderung auch im GAE-Forum angesprochen, aber er, der nur Java kannte, musste am Ende aufgeben.
Natürlich kann man es als Streich verwenden:
Der Code lautet wie folgt:
>>> locals()['True'] = False >>> True False
Eine andere Verwendung besteht darin, zu testen, ob ein Variablenname bereits existiert. Der Standardansatz besteht darin, es zu versuchen ... mit Ausnahme einer NameError-Ausnahme. Tatsächlich können Sie es direkt in locals() oder globals() verwenden, um zu beurteilen.
Lassen Sie mich übrigens eine weitere seltsame Methode vorstellen. Ich weiß nicht, ob es jemand so geschrieben hat:
Der Code lautet wie folgt:
>>> import __main__ >>> hasattr(__main__, 'x') False >>> setattr(__main__, 'x', 1) >>> x 1 >>> hasattr(__main__, 'x') True
Natürlich nein Man empfiehlt Ihnen, es so zu schreiben, und ich auch nicht. Treffen.
Schließlich ist neben dem dynamischen Festlegen von Variablennamen auch ein dynamisches Löschen möglich, z. B. del locals()['x1']. Ebenso ist delattr verfügbar.
Empfohlene verwandte Tutorials: Python-Video-Tutorial
Das obige ist der detaillierte Inhalt vonPython implementiert variable Variablennamen. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!