*参数和** kwargs?

这个问题在这里已经有了答案:

  • **(双星/星号)和*(星号/星号)对参数做什么? 15个答案

  • 语法是*** 。 名字*args**kwargs只是惯例,但没有硬性要求使用它们。

    当你不确定有多少参数可能传递给你的函数时,你会使用*args ,即它允许你传递任意数量的参数给你的函数。 例如:

    >>> def print_everything(*args):
            for count, thing in enumerate(args):
    ...         print( '{0}. {1}'.format(count, thing))
    ...
    >>> print_everything('apple', 'banana', 'cabbage')
    0. apple
    1. banana
    2. cabbage
    

    同样, **kwargs允许您处理您尚未预先定义的命名参数:

    >>> def table_things(**kwargs):
    ...     for name, value in kwargs.items():
    ...         print( '{0} = {1}'.format(name, value))
    ...
    >>> table_things(apple = 'fruit', cabbage = 'vegetable')
    cabbage = vegetable
    apple = fruit
    

    您也可以将它们与命名参数一起使用。 显式参数首先获取值,然后将其他所有内容传递给*args**kwargs 。 命名的参数首先出现在列表中。 例如:

    def table_things(titlestring, **kwargs)
    

    你也可以在同一个函数定义中使用两者,但*args必须在**kwargs之前出现。

    调用函数时,您还可以使用***语法。 例如:

    >>> def print_three_things(a, b, c):
    ...     print( 'a = {0}, b = {1}, c = {2}'.format(a,b,c))
    ...
    >>> mylist = ['aardvark', 'baboon', 'cat']
    >>> print_three_things(*mylist)
    a = aardvark, b = baboon, c = cat
    

    正如你在这种情况下可以看到的那样,它会获取项目的列表(或元组)并将其解压缩。 通过它将它们与函数中的参数相匹配。 当然,你可以在函数定义和函数调用中都有*


    一个使用*args**kwargs非常有用的地方就是子类化。

    class Foo(object):
        def __init__(self, value1, value2):
            # do something with the values
            print value1, value2
    
    class MyFoo(Foo):
        def __init__(self, *args, **kwargs):
            # do something else, don't care about the args
            print 'myfoo'
            super(MyFoo, self).__init__(*args, **kwargs)
    

    通过这种方式,您可以扩展Foo类的行为,而无需知道太多关于Foo的知识。 如果您正在编写可能会更改的API,这可能非常方便。 MyFoo只是将所有参数传递给Foo类。


    这里有一个使用3种不同类型参数的例子。

    def func(required_arg, *args, **kwargs):
        # required_arg is a positional-only parameter.
        print required_arg
    
        # args is a tuple of positional arguments,
        # because the parameter name has * prepended.
        if args: # If args is not empty.
            print args
    
        # kwargs is a dictionary of keyword arguments,
        # because the parameter name has ** prepended.
        if kwargs: # If kwargs is not empty.
            print kwargs
    
    >>> func()
    Traceback (most recent call last):
      File "<stdin>", line 1, in <module>
    TypeError: func() takes at least 1 argument (0 given)
    
    >>> func("required argument")
    required argument
    
    >>> func("required argument", 1, 2, '3')
    required argument
    (1, 2, '3')
    
    >>> func("required argument", 1, 2, '3', keyword1=4, keyword2="foo")
    required argument
    (1, 2, '3')
    {'keyword2': 'foo', 'keyword1': 4}
    
    链接地址: http://www.djcxy.com/p/2991.html

    上一篇: *args and **kwargs?

    下一篇: Sort a Map<Key, Value> by values