主頁 > 知識庫 > Python函數(shù)參數(shù)和注解的使用

Python函數(shù)參數(shù)和注解的使用

熱門標簽:小蘇云呼電話機器人 所得系統(tǒng)電梯怎樣主板設(shè)置外呼 北京電銷外呼系統(tǒng)加盟 朝陽手機外呼系統(tǒng) 北瀚ai電銷機器人官網(wǎng)手機版 儋州電話機器人 地圖標注面積 佛山400電話辦理 市場上的電銷機器人

四種參數(shù)

Python函數(shù)func定義如下:

def func(first, *args, second="Hello World", **kwargs):
    print(first)
    print(args)
    print(second)
    print(kwargs)


func("dongfanger", "san", py="good")

運行后會輸出:

dongfanger
('san',)
Hello World
{'py': 'good'}

它有四種參數(shù):

  • first是定位參數(shù),positional parameter,不可省略。
  • *args是可變參數(shù),arguments,存入元組。
  • second是默認值參數(shù),default argument values,可以省略。
  • **args是關(guān)鍵字參數(shù),keyword arguments,存入字典。

func函數(shù)的調(diào)用方式有以下這些:

①傳入單個定位參數(shù)。

func("dongfanger")  
dongfanger
()
Hello World
{}

②第一個參數(shù)后的任意個參數(shù)會被*args捕獲,存入一個元組。

func("dongfanger", "a", "b", "c")
dongfanger
('a', 'b', 'c')
Hello World
{}

③沒有明確指定名稱的關(guān)鍵字參數(shù)會被**kwargs捕獲,存入一個字典。

func("dongfanger", j="1", k="2")
dongfanger
()
Hello World
{'j': '1', 'k': '2'}

④second只能作為關(guān)鍵字參數(shù)傳入。

func("dongfanger", second="cool")
dongfanger
()
cool
{}

⑤定位函數(shù)也能作為關(guān)鍵字參數(shù)傳入。

func(first="san")
san
()
Hello World
{}

⑥字典前加上**,其所有元素作為單個參數(shù)傳入,同名鍵會綁定到對應(yīng)具名參數(shù)上,余下的被**args捕獲。

my_dict = {"first": "dongfanger", "location": "cd", "second": "cool", "age": "secret"}
func(**my_dict)
dongfanger
()
cool
{'location': 'cd', 'age': 'secret'}

除了這四種參數(shù),還有一種Python3新增加的僅限關(guān)鍵字參數(shù)。

僅限關(guān)鍵字參數(shù)

僅限關(guān)鍵字參數(shù)(keyword-only argument)是Python3的新特性,func函數(shù)的second參數(shù)就是僅限關(guān)鍵字參數(shù),“僅限”的意思是說,只能通過關(guān)鍵字參數(shù)指定,它一定不會捕獲未命名的定位參數(shù)。

假如把參數(shù)位置調(diào)整一下定義another_func函數(shù):

def another_func(first, another_second="Hello World", *args,  **kwargs):
    print(first)
    print(another_second)
    print(args)
    print(kwargs)


another_func("dongfanger", "a", "b", "c")

輸出會變成:

dongfanger
a  # 注意這里
('b', 'c')
{}

another_second不是僅限關(guān)鍵字參數(shù),而只是默認值參數(shù),因為它捕獲到了定位參數(shù)。

由此得知,定義僅限關(guān)鍵字參數(shù),必須把它放到*args參數(shù)后面,就像func函數(shù)一樣,反例是another_func函數(shù)。

還有第二個方法定義僅限關(guān)鍵字參數(shù),在簽名中放一個*:

>>> def f(a, *, b):  # b是僅限關(guān)鍵字參數(shù)
...    return a, b
...
>>> f(1, b=2)  # 只能傳關(guān)鍵字參數(shù)
(1, 2)
>>> f(1, 2)  # 不能傳定位參數(shù)
Traceback (most recent call last):
  File "input>", line 1, in module>
TypeError: f() takes 1 positional argument but 2 were given
>>> f(1, 2, 3)  # 不能傳定位參數(shù)
Traceback (most recent call last):
  File "input>", line 1, in module>
TypeError: f() takes 1 positional argument but 3 were given

僅限關(guān)鍵字參數(shù)不一定要有默認值,就像b一樣,強制必須傳入實參。

內(nèi)省中的函數(shù)參數(shù)

函數(shù)內(nèi)省的意思是說,當你拿到一個“函數(shù)對象”的時候,你可以繼續(xù)知道,它的名字,參數(shù)定義等信息。這些信息可以通過函數(shù)對象的屬性(一些雙下劃線的魔法方法)得到。

對于func函數(shù):

def func(first, *args, second="Hello World", **kwargs):
    print(first)
    print(second)
    print(args)
    print(kwargs)

和another_func函數(shù):

def another_func(first, another_second="Hello World", *args,  **kwargs):
    print(first)
    print(another_second)
    print(args)
    print(kwargs)

【__defaults__屬性】

元組,保存著定位參數(shù)和關(guān)鍵字參數(shù)的默認值。

print(func.__defaults__)  # None

print(another_func.__defaults__)  # ('Hello World',)

【__kwdefaults__屬性】

字典,保存僅限關(guān)鍵字參數(shù)。

print(func.__kwdefaults__)  # {'second': 'Hello World'}

print(another_func.__kwdefaults__)  # None

【__code__屬性】

code對象引用,code對象自身有很多屬性,其中包括參數(shù)名稱。

print(func.__code__.co_varnames)  # ('first', 'second', 'args', 'kwargs')

print(another_func.__code__.co_varnames)  # ('first', 'another_second', 'args', 'kwargs')

另外還可以使用inspect庫的signature方法來查看內(nèi)省中的函數(shù)參數(shù):

from inspect import signature

print(signature(func))  
# (first, *args, second='Hello World', **kwargs)

框架和IDE等工具可以使用這些信息驗證代碼。

函數(shù)注解

如果刷過力扣算法題,那么對函數(shù)注解就不會陌生。比如:

def clip(text:str, max_len:'int > 0'=80) -> str:
    pass

參數(shù):后面是注解表達式,可以用來注解參數(shù)類型和約束。如果參數(shù)有默認值,注解放在參數(shù)名和=號之間。

可以在函數(shù)末尾的)和:之間添加->和注解表達式,來對返回值添加注解。

注解表達式可以是任何類型,最常用的類型是類(如str或int)和字符串(如'int > 0')。

函數(shù)注解只是個注解,Python對注解所做的唯一的事情是,把它們存入函數(shù)的__annotations__屬性中:

print(clip.__annotations__)
#{'text': class 'str'>, 'max_len': 'int > 0', 'return': class 'str'>}

Python不做檢查,不做強制,不做驗證,什么操作都不做!注解只是元數(shù)據(jù),可以供框架和IDE等工具使用。

以上就是Python函數(shù)參數(shù)和注解的使用的詳細內(nèi)容,更多關(guān)于Python函數(shù)參數(shù)和注解的資料請關(guān)注腳本之家其它相關(guān)文章!

您可能感興趣的文章:
  • python教程對函數(shù)中的參數(shù)進行排序
  • Python 類,對象,數(shù)據(jù)分類,函數(shù)參數(shù)傳遞詳解
  • Python函數(shù)中的不定長參數(shù)相關(guān)知識總結(jié)
  • 詳解Python 函數(shù)參數(shù)的拆解
  • Python函數(shù)參數(shù)定義及傳遞方式解析
  • 關(guān)于Python函數(shù)參數(shù)的進階用法

標簽:江蘇 商丘 定西 云南 酒泉 寧夏 龍巖 金融催收

巨人網(wǎng)絡(luò)通訊聲明:本文標題《Python函數(shù)參數(shù)和注解的使用》,本文關(guān)鍵詞  Python,函數(shù),參數(shù),和,注解,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《Python函數(shù)參數(shù)和注解的使用》相關(guān)的同類信息!
  • 本頁收集關(guān)于Python函數(shù)參數(shù)和注解的使用的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章