https://py.eastlakeside.cn/book/Syntax/args_kwargs.html

args 和 *kwargs

其实并不是必须写成 args 和 **kwargs。只有变量前面的 (星号)才是必须的。你也可以写成 var 和 **vars。而写成 args 和 *kwargs 只是一个通俗的命名约定。那就让我们先看一下 args 吧。

*args 的用法

args 和 kwargs 主要用于函数定义。 你可以将不定数量的参数传递给一个函数
这里的不定的意思是:
预先并不知道,函数使用者会传递多少个参数给你,所以在这个场景下使用这两个关键字**。
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')

这会产生如下输出

  1. first normal arg: yasoob
  2. another arg through *argv: python
  3. another arg through *argv: eggs
  4. another arg through *argv: test

我希望这解决了你所有的困惑。那接下来让我们谈谈 **kwargs。

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

现在你可以看出我们怎样在一个函数里,处理了一个键值对参数了。
这就是 kwargs 的基础,而且你可以看出它有多么管用。接下来让我们谈谈,你怎样使用 *args 和 kwargs 来调用一个参数为列表或者字典的函数。

补充

items()方法
Python 字典(Dictionary) items() 函数以列表返回可遍历的(键, 值) 元组数组。

  1. tinydict = {'Google': 'www.google.com', 'Runoob': 'www.runoob.com', 'taobao': 'www.taobao.com'}
  2. print "字典值 : %s" % tinydict.items()
  3. # 遍历字典列表
  4. for key,values in tinydict.items():
  5. print key,values
  6. ----
  7. 字典值 : [('Google', 'www.google.com'), ('taobao', 'www.taobao.com'), ('Runoob', 'www.runoob.com')]
  8. Google www.google.com
  9. taobao www.taobao.com
  10. Runoob www.runoob.com

使用 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来给这个小函数传递参数。下面是怎样做:

  1. # 首先使用 *args
  2. >>> args = ("two", 3, 5)
  3. >>> test_args_kwargs(*args)
  4. arg1: two
  5. arg2: 3
  6. arg3: 5
  7. # 现在使用 **kwargs:
  8. >>> kwargs = {"arg3": 3, "arg2": "two", "arg1": 5}
  9. >>> test_args_kwargs(**kwargs)
  10. arg1: 5
  11. arg2: two
  12. arg3: 3

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

那么如果你想在函数里同时使用所有这三种参数, 顺序是这样的:

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

什么时候使用它们?

这还真的要看你的需求而定。
最常见的用例是在写函数装饰器的时候(会在另一章里讨论)。
此外它也可以用来做猴子补丁(monkey patching)。猴子补丁的意思是在程序运行时(runtime)修改某些代码。打个比方,你有一个类,里面有个叫 get_info 的函数会调用一个API并返回相应的数据。如果我们想测试它,可以把API调用替换成一些测试数据。例如:

  1. import someclass
  2. def get_info(self, *args):
  3. return "Test data"
  4. someclass.get_info = get_info

我敢肯定你也可以想象到一些其他的用例。