Heim > Backend-Entwicklung > Python-Tutorial > Wie bewahrt „functools.wraps' Funktionsmetadaten in Python-Dekoratoren?

Wie bewahrt „functools.wraps' Funktionsmetadaten in Python-Dekoratoren?

Mary-Kate Olsen
Freigeben: 2024-11-30 05:52:22
Original
676 Leute haben es durchsucht

How Does `functools.wraps` Preserve Function Metadata in Python Decorators?

Enthüllung der Geheimnisse von functools.wraps: Funktionsmetadaten pflegen

Dekoratoren spielen eine entscheidende Rolle bei der Erweiterung der Funktionalität von Python-Funktionen. Sie gehen jedoch häufig mit dem Verlust wichtiger Funktionsmetadaten wie Name, Dokumentzeichenfolge und Argumentliste einher. Glücklicherweise erweist sich functools.wraps als Retter und bewahrt diese unschätzbaren Informationen.

Beim Anwenden eines Dekorators wird die ursprüngliche Funktion durch eine Wrapper-Funktion ersetzt, wodurch bestimmte wichtige Details verdeckt werden. Betrachten Sie zum Beispiel das folgende Beispiel:

def logged(func):
    def with_logging(*args, **kwargs):
        print(func.__name__ + " was called")
        return func(*args, **kwargs)
    return with_logging

@logged
def f(x):
    """does some math"""
    return x + x * x
Nach dem Login kopieren

Wenn Sie print(f.__name__) ausführen, wird „with_logging“ zurückgegeben und f.__doc__ gibt eine leere Zeichenfolge zurück. Diese Konsequenz entsteht, weil die Wrapper-Funktion with_logging an die Stelle von f getreten ist.

functools.wraps behebt dieses Problem, indem es die Dekoratorfunktion umschließt und sicherstellt, dass die Metadaten der dekorierten Funktion intakt bleiben. Indem wir @wraps(func) auf die innere Funktion anwenden, wie unten gezeigt, stellen wir das gewünschte Verhalten wieder her:

from functools import wraps
def logged(func):
    @wraps(func)
    def with_logging(*args, **kwargs):
        print(func.__name__ + " was called")
        return func(*args, **kwargs)
    return with_logging

@logged
def f(x):
    """does some math"""
    return x + x * x

print(f.__name__)  # prints 'f'
print(f.__doc__)   # prints 'does some math'
Nach dem Login kopieren

In diesem überarbeiteten Beispiel zeigt f.__name__ „f“ an und f.__doc__ spiegelt es korrekt wider die Dokumentzeichenfolge der ursprünglichen Funktion. Die Erhaltung der Metadaten ist für die Aufrechterhaltung der Identität, Dokumentation und Selbstbeobachtungsfähigkeiten der Funktion von entscheidender Bedeutung.

Denken Sie daher daran, dass functools.wraps ein wesentliches Werkzeug im Decorator-Toolkit ist, das vor Informationsverlust schützt und sicherstellt, dass Ihre dekorierten Funktionen ihre Eigenschaften behalten beabsichtigte Attribute.

Das obige ist der detaillierte Inhalt vonWie bewahrt „functools.wraps' Funktionsmetadaten in Python-Dekoratoren?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
Erklärung dieser Website
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
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage