Heim  >  Artikel  >  Backend-Entwicklung  >  Python implementiert variable Variablennamen

Python implementiert variable Variablennamen

步履不停
步履不停Original
2019-07-01 14:44:063494Durchsuche

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!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Vorheriger Artikel:So verwenden Sie Pythons PipNächster Artikel:So verwenden Sie Pythons Pip