首頁 > 軟體

詳解Python中*args和**kwargs的使用

2022-04-07 13:01:26

1. 引言

在本文中,我們將討論 Python 中的 *args 和 **kwargs 及其用法和範例。

閒話少說,我們直接開始吧。

2. 問題引入

在Python中寫函數的時候,我們經常需要給函數傳值,這些值被稱為函數引數。

我們不妨來舉個栗子,我們實現加法運算如下:

def add(x,y):
    return x+y
print(add(2,3))

輸出:

5

如果進一步來說,我們需要實現三個數位求和的操作呢?很簡單,我們可以修改函數以接受三個引數並將它們的總和返回,程式碼如下:

def add(x, y, z):
    return x+y+z

print(add(2, 3, 5))

輸出:

10

如果此時我們又需要對四個數位求和呢?如果又變成五個數位求和呢?

當我們有可變數量的引數時,就會出現問題。我們是否應該繼續修改函數以接受確切數量的引數?當然不是,我們不會這樣做。實際上,以上場景為*args 和 **kwargs大顯身手的地方。

3. Python中的*args

*args 允許我們將可變數量的引數傳遞給 Python中相應的函數。在函數中,我們應該在引數名稱前使用 * 來表示傳遞可變數量的引數。

樣例程式碼如下:

def add(*args):
    print(args, type(args))
add(2, 3)

輸出如下:

(2, 3) <class 'tuple'>

因此,我們確定這些傳遞的引數在函數內部建立了一個元組,接著我們就可以據此來寫相應的加法函數,如下所示:

def add(*numbers):
    total = 0
    for num in numbers:
        total += num
    return total

呼叫程式碼如下:

print(add(2, 3))
print(add(2, 3, 5))
print(add(2, 3, 5, 7))
print(add(2, 3, 5, 7, 9))

輸出如下:

5
10
17
26

需要注意的是,上述函數的引數的名稱不一定是 args,它可以是任何其他名字,在上述程式碼中,它是numbers,但是通常的做法就是使用 *args 作為函數引數名稱來表示該引數是一個可變數量的引數。

4. Python中的**kwargs

kwargs 是 keyword arguments 的縮寫,表示關鍵字引數。** kwargs 允許我們將可變數量的關鍵字引數傳遞給 Python函數。在函數中,我們在引數名稱前使用雙星號 ** 來表示這種型別的引數。

樣例程式碼如下:

def total_fruits(**kwargs):
    print(kwargs, type(kwargs))
total_fruits(banana=5, mango=7, apple=8)

輸出如下:

{'banana': 5, 'mango': 7, 'apple': 8} <class 'dict'>

此時我們可以看到,在上述情況下,字典作為引數進行傳遞,並且這些引數在函數內部建立了一個字典,接著,我們可以實現函數 total_fruits() 用以返回水果的總數。

def total_fruits(**fruits):
    total = 0
    for amount in fruits.values():
        total += amount
    return total

呼叫程式碼如下:

print(total_fruits(banana=5, mango=7, apple=8))
print(total_fruits(banana=5, mango=7, apple=8, oranges=10))
print(total_fruits(banana=5, mango=7))

輸出如下:

20
30
12 

需要注意的是,引數的名稱不一定是 kwargs,它可以是任何名字,在上述程式碼中,它是**fruits。但是通常的做法就是使用 **kwargs 作為函數引數名稱來表示該引數是一個可變數量的關鍵字引數。

5. 總結

args和kwargs可以組合起來可以傳入任意的引數,這在引數未知的情況下是很有效的,同時加強了函數的可拓展性。

到此這篇關於詳解Python中*args和**kwargs的使用的文章就介紹到這了,更多相關Python *args  **kwargs內容請搜尋it145.com以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援it145.com!


IT145.com E-mail:sddin#qq.com