您好,登錄后才能下訂單哦!
這篇文章主要講解了“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進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。