Heim >Backend-Entwicklung >Python-Tutorial >Detaillierte Erklärung der *args und **kwargs von Python

Detaillierte Erklärung der *args und **kwargs von Python

高洛峰
高洛峰Original
2016-10-17 16:19:251990Durchsuche

*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, ) 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 , die restlichen 2, 3 und 4 werden *args zugewiesen, und die anderen werden **kwargs zugewiesen


Es gibt auch eine sehr schöne Verwendung, nämlich zu Erstellen Sie ein Wörterbuch:

def kw_dict(**kwargs):
    return kwargs
print kw_dict(a=1,b=2,c=3)

Ergebnis:

{'a':1, 'b':2, 'c':3}

Tatsächlich Es gibt eine Dict-Klasse. Verwenden Sie dict(a=1,b=2,c=3), um ein Wörterbuch zu erstellen.


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