这篇文章主要讲解了“django中的*args 与 **kwargs用法是什么 ”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“django中的*args 与 **kwargs用法是什么 ”吧!
*args表示任何多个无名参数,它是一个tuple
**kwargs表示关键字参数,它是一个dict
def foo(*args,**kwargs): print 'args=',args print 'kwargs=',kwargs print '**********************' if __name__=='__main__': foo(1,2,3) foo(a=1,b=2,c=3) foo(1,2,3,a=1,b=2,c=3) foo(1,'b','c',a=1,b='b',c='c')
args= (1, 2, 3) kwargs= {} ********************** args= () kwargs= {'a': 1, 'c': 3, 'b': 2} ********************** args= (1, 2, 3) kwargs= {'a': 1, 'c': 3, 'b': 2} ********************** args= (1, 'b', 'c') kwargs= {'a': 1, 'c': 'c', 'b': 'b'} **********************
补充:Python中的**kwargs和*args这么理解
Python中经常看到**kwargs和*args这么两个参数,例如下面groupby的参数。
到底是什么意思呢?
怎么使用?
DataFrame.groupby(by=None, axis=0, level=None, as_index= True, sort=True, group_keys=True, squeeze=False, observed=False, **kwargs)
*args和**kwargs一般是用在函数定义的时候。二者的意义是允许定义的函数接受任意数目的参数。也就是说我们在函数被调用前并不知道也不限制将来函数可以接收的参数数量。在这种情况下我们可以使用*args和**kwargs。
*args用来表示函数接收可变长度的非关键字参数列表作为函数的输入。我们可以通过以下这个例子来进一步理解*args。
def test_args(normal_arg, *args): print("first normal arg:" + normal_arg) for arg in args: print("another arg through *args :" + arg) test_args("normal", "python", "java", "C#")
上面代码的执行结果如下:
first normal arg: normal another arg through *args : python another arg through *args : java another arg through *args :C#
**kwargs表示函数接收可变长度的关键字参数字典作为函数的输入。当我们需要函数接收带关键字的参数作为输入的时候,应当使用**kwargs。我们可以通过以下这个例子来进一步理解**kwargs。
def test_kwargs(**kwargs): if kwargs is not None: for key, value in kwargs.iteritems(): print("{} = {}".format(key,value)) # Or you can visit kwargs like a dict() object # for key in kwargs: # print("{} = {}".format(key, kwargs[key])) test_kwargs(name="python", value="5")
以上代码的执行结果如下:
name = python value = 5
以上例子只是*args和**kwargs的基本的使用例子。下面再给出一个用*args和**kwargs来定义能够接收列表输入和字典输入的函数的例子。
比如我们有如下接收普通输入参数的函数:
def normal_func(arg1, arg2, arg3): print("arg1: " + arg1) print("arg2: " + arg2) print("arg3: " + arg3) normal_func("python", 1, 3)
使用*args和**kwargs来调用这个函数的代码如下:
# 使用*args args_list = ("python", 1, 3) normal_func(*args_list) # 使用**kwargs kwargs_dict = {"arg3": 3, "arg1": "python", "arg2": 1} normal_func(**kwargs_dict)
以上三段代码的输出均为:
arg1: python arg2: 1 arg3: 3
*args和**kwargs都指定义函数时其内部参数数量问题,不指定具体数量,依据使用时具体情况而临场确定数量。
*args针对非关键字参数,**kwargs针对关键字参数。
不仅在定义函数时有空,并且可以作为函数实际调用时作为参数使用。
感谢各位的阅读,以上就是“django中的*args 与 **kwargs用法是什么 ”的内容了,经过本文的学习后,相信大家对django中的*args 与 **kwargs用法是什么 这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是亿速云,小编将为大家推送更多相关知识点的文章,欢迎关注!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。