*args**kwargs

⾸先,要知道的是并不是必须写成*args**kwargs。 只有变量前⾯的*才是必须的。所以,你也可以写成*var**vars。写成*args**kwargs只是⼀个通俗的命名约定。

*args**kwargs 主要⽤于函数定义。 你可以将不定数量的参数传递给⼀个函数。

这⾥的不定的意思是:预先并不知道,函数使⽤者会传递多少个参数,所以在这个场景下使⽤这两个关键字。

*args 的⽤法

*args是⽤来发送⼀个⾮键值对的可变数量的参数列表给⼀个函数。

来看一个例子,可以帮助理解:

  1. def test_var_args(f_arg, *argv):
  2. print("first normal arg:", f_arg)
  3. for arg in argv:
  4. print("another arg through *argv:", arg)
  5. >>> test_var_args('yasoob', 'python', 'eggs', 'test')
  6. first normal arg: yasoob
  7. another arg through *argv: python
  8. another arg through *argv: eggs
  9. another arg through *argv: test

**kwargs的⽤法

**kwargs 允许将不定长度键值对,作为参数传递给⼀个函数。 如果你想要在⼀个函数⾥处理带名字的参数,应该使⽤**kwargs

  1. def greet_me(**kwargs):
  2. for key, value in kwargs.items():
  3. print("{0} == {1}".format(key, value))
  4. >>> greet_me(name="yasoob")
  5. name == yasoob

使⽤ *args**kwargs 来调⽤函数

接下来学习一下怎样使⽤*args**kwargs来调⽤⼀个参数为列表或者字典的函数。

现在有这样⼀个函数:

  1. def test_args_kwargs(arg1, arg2, arg3):
  2. print("arg1:", arg1)
  3. print("arg2:", arg2)
  4. print("arg3:", arg3)

可以使⽤*args**kwargs来给这个函数传递参数。 比如这样使用*args

  1. >>> args = ("two", 3, 5)
  2. >>> test_args_kwargs(*args)
  3. arg1: two
  4. arg2: 3
  5. arg3: 5

或者使用**kwargs

  1. >>> kwargs = {"arg3": 3, "arg2": "two", "arg1": 5}
  2. >>> test_args_kwargs(**kwargs)
  3. arg1: 5
  4. arg2: two
  5. arg3: 3

标准参数与*args**kwargs在使⽤时的顺序

  1. some_func(fargs, *args, **kwargs)

啥时候⽤

  • 最常见的⽤例是在写函数装饰器的时候。
  • 它也可以⽤来做猴⼦补丁

参考