Heim > Artikel > Backend-Entwicklung > Vergleichende Erklärung der Verwendung von *args und **kwargs in Python
*args stellt mehrere unbenannte Parameter dar, was ein Tupel ist; **kwargs stellt Schlüsselwortparameter dar, was ein Diktat ist.
def fun(*args, **kwargs): print 'args = ', args print 'kwargs = ', kwargs print '###' if __name__ == '__main__': foo(1,2,3,4) foo(a=1,b=2,c=3) foo(1,2,3,4, a=1,b=2,c=3) foo('a', 1, None, a=1, b='2', c=3)
Die Ausgabeergebnisse lauten wie folgt:
args = (1, 2, 3, 4) kwargs = {} ### args = () kwargs = {'a': 1, 'c': 3, 'b': 2} ### args = (1, 2, 3, 4) kwargs = {'a': 1, 'c': 3, 'b': 2} ### args = ('a', 1, None) kwargs = {'a': 1, 'c': 3, 'b': '2'} ###
Wie Sie sehen können, handelt es sich bei diesen beiden um variable Parameter in Python.
Hinweis: Bei gleichzeitiger Verwendung von *args und **kwargs muss der Parameter *args vor **kwargs aufgeführt werden, wie foo(a=1, b='2', c =3, a', 1, None, ) führt zu einem Syntaxfehler „SyntaxError: non-keyword arg after keyword arg“.
def fun2(param1, *args, **kwargs): print 'param1 = ', param1 print 'args = ', args print 'kwargs = ', kwargs print '###' fun2(1, 2, 3, 4, a=1,b=2,c=3)
Ausgabeergebnis:
param1 = 1 args = (2,3,4) kwargs = {'a': 1, 'c': 3, 'b': 2} ###
1 wird param1 zugewiesen, die restlichen 2, 3 und 4 werden *args zugewiesen und die anderen werden zugewiesen * *kwargs
Es gibt auch eine sehr schöne Verwendung, nämlich das Erstellen eines Wörterbuchs:
def kw_dict(**kwargs): return kwargs print kw_dict(a=1,b=2,c=3)
Ergebnis:
{'a':1, 'b':2, 'c':3}
Tatsächlich gibt es ein dict-Klasse in Python, verwenden Sie dict(a=1,b=2,c=3), um ein Wörterbuch zu erstellen.
Das obige ist der detaillierte Inhalt vonVergleichende Erklärung der Verwendung von *args und **kwargs in Python. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!