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

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

大家讲道理
大家讲道理Original
2016-11-07 11:07:471267Durchsuche

*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.

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