谈一谈python中的魔法变量*args和**kwargs

导读

最近看了看github大佬写的代码后,发现自己之前写的代码就是个,没有注释,没有封装,没有可读性。哎,幸亏发现及时,现在正在写一个新的任务,刚好可以好好弄弄架构和代码了

在弄代码期间发现了*args和**kwargs这两个参数大佬们有时候经常用,当然最多的其实是在阅读python自己的源代码的时候最长见了,今天我终于了解清楚它们到底是啥了,大家一起来看!

小小声明

先弄个声明哈,*args和**kwargs这种写法不是必须的,只有前面的 * 才是必须的。当然你也可以写成*var和**vars,而写成*args和**kwargs是一个约定俗成的一个命名规范而已。

*args的用法

*args和**kwargs主要用于函数定义。功能是将不确定数量的参数传递给一个函数。

这里说说*args,它是用来发送一个非键值对的可变数量的参数列表给一个函数。

吃个栗子:

def test_var_args(f_arg, *args):
  print("first normal arg:", f_arg)
  for arg in args:
      print("another arg through *args:", arg)

test_var_args('zero', 'one', 'two', 'three')

输出结果为:

first normal arg: one
another arg through *args: one
another arg through *args: two
another arg through *args: three

懂了吧,咱们进行下一个**kwargs!

**kwargs的用法

上面的*args说的是非键值对,所以这里肯定就是键值对啦。如果你想要一个函数里传入带名字的参数,就可以用**kwargs。

吃个栗子:

def test_var_kwargs(**kwargs):
   for key, value in kwargs.items():
       print("{0} == {1}".format(key, value))


>>> test_var_kwargs(arg0="zero",arg1="one")
arg0 == zero
arg1 == one

简单吧。接下来我们谈谈如何使用*args和**kwargs来调用一个参数为列表或字典的函数!

使用*args和**kwargs来调用函数

假设你要实现这样的一个函数:

def test_args_kwargs(arg1, arg2, arg3):
   print("arg1:", arg1)
   print("arg2:", arg2)
   print("arg3:", arg3)

你可以这样使用*args和**kwargs:

# 首先使用 *args
>>> args = ("two", 3, 5)
>>> test_args_kwargs(*args)
arg1: two
arg2: 3
arg3: 5

# 现在使用 **kwargs:
>>> kwargs = {"arg3": 3, "arg2": "two", "arg1": 5}
>>> test_args_kwargs(**kwargs)
arg1: 5
arg2: two
arg3: 3

*args和**kwargs的使用顺序

如果你想要使用所有的参数情况的话,他们的顺序是这样的:

some_func(fargs, *args, **kwargs)

*args是可变的positional arguments列表,**kwargs是可变的keyword arguments列表。并且,*args必须位于**kwargs之前,因为positional arguments必须位于keyword arguments之前。

如何一起学习,有没有免费资料?

对Python开发技术感兴趣的同学,欢迎加QQ群:865597862,一起学习,相互讨论。

群内已经有小伙伴将知识体系整理好(源码,笔记,PPT,学习视频),欢迎加群免费领取。

猜你喜欢

转载自blog.csdn.net/qq_42207221/article/details/83088901