Wie man Python -Objekt unabwährt macht
Um ein Python-Objekt unveränderlich zu machen, kann es auf folgende Weise implementiert werden: 1. Slots und private Eigenschaftenkapselung, setzen Sie die Eigenschaft auf privat und bieten eine schreibgeschützte Eigenschaft; 2.. Erben Sie Tuple oder verwenden Sie benannte Tuple, geeignet für feste Datenkombinationen; 3. Verwenden Sie den gefrorenen = echten Parameter von Dataclass, der präzise ist und die Typ -Eingabeaufforderungen unterstützt. V. Die spezifische Wahl hängt von den Anforderungen ab. Wenn nur Daten gespeichert sind, werden zuerst benannte Tuple oder Dataclass verwendet. Wenn die Kapselungslogik erforderlich ist, werden gewöhnliche Klassen verwendet, um Attributbeschränkungen zu kombinieren.
Das Erstellen eines Python-Objekts unveränderlich wird nicht direkt durch ein bestimmtes Schlüsselwort oder ein integriertes Mechanismus erreicht, kann jedoch durch einige Entwurfsmuster und Sprachmerkmale simuliert werden. Der Schlüssel ist, dass der Status des Steuerobjekts nach der Erstellung nicht geändert werden kann.

1.. Einkapseln Sie mit __slots__
und privaten Attributen ein
Dies ist eine der grundlegendsten Praktiken. Sie können die Eigenschaften der Klasse auf privat einstellen und keine Änderungsmethoden bereitstellen.

Klasse Unternehmerpunkt: __slots__ = ('_x', '_y') def __init __ (self, x, y): self._x = x self._y = y @Eigentum def x (selbst): return self._x @Eigentum definitiv (Selbst): Return self._y
- Der Wert kann nur durch die Eigenschaften von
x
undy
draußen erhalten werden. - Da
__slots__
verwendet wird, können Benutzer nach Belieben keine neuen Attribute hinzufügen. - Diese Methode eignet sich für Szenarien, in denen eine benutzerdefinierte Logik erforderlich ist und die Unveränderlichkeit erwünscht ist.
2. Erben Sie tuple
oder verwenden Sie namedtuple
Wenn Ihr Objekt im Wesentlichen ein fester Satz von Datenkombinationen ist, ist die Verwendung von tuple
oder namedtuple
die natürlichste Art und Weise.
aus den Sammlungen importieren namedtuple Point = namedTuple ('point', ['x', 'y']) p = Punkt (1, 2) # px = 3 # meldet einen Fehler
- Sowohl
tuple
als auchnamedtuple
sind von Natur aus unveränderlich. - Sie sind leicht und effizient, wodurch sie für Datenbehälter geeignet sind.
- Der Nachteil ist, dass es nicht flexibel genug ist, z.
3. Verwenden Sie frozen=True
dataclass
Python 3.7 führt dataclass
ein, wodurch die generierte Klasse mit dem Parameter frozen=True
unablässig gestaltet werden kann.

aus DataClasses importieren Sie DataClass @dataclass (gefroren = true) Klassenpunkt: X: int Y: int p = Punkt (1, 2) # px = 3 # Wirf eine Ausnahme
- Präzise und leicht zu lesen, geeignet, um Datenmodelle schnell zu definieren.
- Eingebaute Support-Eingabeaufforderungen.
- Wenn Sie Vergleich, Hashing, String -Repräsentation und andere Funktionen benötigen, hilft dies Ihnen auch, dies standardmäßig zu erreichen.
4. Schreiben Sie die Methoden im Zusammenhang mit Zuweisungen in benutzerdefinierten Klassen um
Wenn Sie keine gefrorenen Klassen verwenden möchten, können Sie auch das Zuordnungsverhalten manuell steuern, z. B. eine Ausnahme:
Klasse strengmarkig: def __init __ (Selbst, Wert): self._Value = Wert @Eigentum Def Value (Selbst): Return self._Value Def __setattr __ (Selbst, Schlüssel, Wert): Wenn Key == '_Value': Super () .__ Setattr __ (Schlüssel, Wert) anders: Erhöhen Sie AttributeError ("" Unveränderliche Instanz kann nicht ändern ")
- Flexibler können Sie steuern, welche Felder geändert werden können und welche nicht geändert werden können.
- Die Wartungskosten sind jedoch geringfügig höher und einige Eingänge können leicht übersehen (z. B.
__delattr__
).
Grundsätzlich diese gemeinsamen Praktiken. Welche Sie auswählen können, hängt von Ihren Anforderungen ab: Wenn Sie nur Daten speichern, geben Sie namedtuple
oder dataclass
Priorität. Wenn Sie eine Kapselungslogik benötigen, können Sie normale Klassen verwenden, um die Einschränkungen für Kapselungsattributbeschränkungen zu kombinieren.
Das obige ist der detaillierte Inhalt vonWie man Python -Objekt unabwährt macht. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Heiße KI -Werkzeuge

Undress AI Tool
Ausziehbilder kostenlos

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Clothoff.io
KI-Kleiderentferner

Video Face Swap
Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heißer Artikel

Heiße Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Um eine virtuelle Python -Umgebung zu erstellen, können Sie das Venv -Modul verwenden. Die Schritte sind: 1. Geben Sie das Projektverzeichnis ein, um die Python-Mvenvenv-Umgebung auszuführen, um die Umgebung zu schaffen. 2. verwenden Sie SourceEnv/bin/aktivieren Sie in Mac/Linux und Env \ Skripts \ aktivieren in Windows; 3.. Verwenden Sie das Pipinstall -Installationspaket, Pipfreeze> Anforderungen.txt, um Abhängigkeiten zu exportieren. V. Virtuelle Umgebungen können Projektabhängigkeiten isolieren, um Konflikte zu verhindern, insbesondere für die Entwicklung von Mehrfachprojekten, und Redakteure wie Pycharm oder VSCODE sind es ebenfalls

UsetracemalloctoTrackMemoryAllocations undidentififyHigh-Memorindininen; 2.MonitorObjectCountswithgcandobjgraphoToDeCtGrowingObjecttypes;

Usezoneinfoforpython3.9 tocreateTimezon-altertätiges und convertbetweentimezoneswithastimezone (); 2.Forpython3.6–3.8, UsePyTZWithLocalize () ToavoidDsterrors;

Die Methode zum Ausfüllen von Excel -Daten in Webformulare mithilfe von Python lautet: Verwenden Sie zunächst Pandas, um Excel -Daten zu lesen und dann mit Selen das Browser zu steuern, um das Formular automatisch zu füllen und zu übermitteln. Zu den spezifischen Schritten gehören die Installation von Pandas, OpenPyxl- und Selenium -Bibliotheken, das Herunterladen des entsprechenden Browsertreibers, die Verwendung von Pandas zum Lesen von Namen, E -Mails, Telefon und anderen Feldern in der Datei data.xlsx, starten Sie den Browser über Selen, um das Ziel -Last zu erstellen. Wenn Sie die Ausnahme des Stellverfahrens verarbeiten, können Sie die Ausnahme des Stellverfahrens verarbeiten. Formieren und verarbeiten Sie alle Datenlinien in einer Schleife.

Um die Werte des Wörterbuchs zu sortieren, verwenden Sie die Funktion Sortled () so, dass sie mit den Dict.Items () und den Schlüsselparametern übereinstimmen. 1. Verwenden Sie Lambdaitem: Element [1], um durch aufsteigende Ordnung zu sortieren; 2. Hinzufügen von Reverse = true, um absteigende Reihenfolge zu implementieren; 3. Verwenden Sie den Bediener. ITEMGERTTER (1), um Lambda zu ersetzen, um die Lesbarkeit und Leistung zu verbessern. Das Wörterbuch behält die Insertionsordnung in Python 3.7 bei, das ursprüngliche Wörterbuch bleibt unverändert und gibt ein neues Wörterbuch zurück. Wenn die Werttypen gemischt sind, ist eine zusätzliche Verarbeitung erforderlich, und das endgültige Muster ist diktiert (sortiert (d.Items (), key = lambdax: x [1]).

Erstellen Sie eine virtuelle Umgebung: Führen Sie Python-mvenvvenv im Projektordner aus. 2. Aktivieren Sie die virtuelle Umgebung: Windows verwendet Venv \ scripts \ aktivieren, MacOS/Linux verwendet SourceVenv/bin/activate. 3. Öffnen Sie das Projekt in VSCODE und drücken Sie STRG Shift P, um den Python -Interpreter auszuwählen. Geben Sie den Interpreter in der virtuellen Umgebung an. 4. Überprüfen Sie, ob es effektiv ist: Führen Sie die Importsys aus; drucken (sys.execable), und der Ausgangspfad sollte auf den Griffordner verweisen. 5. Optionale Konfiguration: Aktivieren Sie python.terminal.a in Einstellungen

Um JSON -Dateien zu verschönern und zu drucken, müssen Sie die Einstellparameter des JSON -Moduls verwenden. Die spezifischen Schritte sind: 1. Verwenden Sie JSON.LOAD (), um die JSON -Dateidaten zu lesen; 2. Verwenden Sie JSON.DUMP () und setzen Sie den Einzug auf 4 oder 2, um in eine neue Datei zu schreiben, und dann kann die formatierte JSON -Datei generiert werden und der verschönernde Druck kann abgeschlossen werden.

Define__iter __ () toreturn theiteratorObject, typisch SelfoRaseParateiterinInstance
