Heim >Backend-Entwicklung >Python-Tutorial >Detaillierte Erklärung der *args und **kwargs von 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)
Das Ausgabeergebnis ist 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, ) Bei einem Aufruf auf diese Weise wird der Syntaxfehler „SyntaxError: non-keyword arg after keyword arg“ angezeigt.
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, und die restlichen 2, 3 und 4 werden zugewiesen zu * args, andere werden **kwargs zugewiesen
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 in Python eine dict-Klasse. Sie können ein Wörterbuch mit dict(a=1,b=2,c=3) erstellen.