一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

腳本之家,腳本語言編程技術及教程分享平臺!
分類導航

Python|VBS|Ruby|Lua|perl|VBA|Golang|PowerShell|Erlang|autoit|Dos|bat|

服務器之家 - 腳本之家 - Python - Python函數參數和注解的使用

Python函數參數和注解的使用

2021-11-19 13:29自動化代碼美學 Python

本文介紹了Python函數的四種參數:定位參數、可變參數、默認值參數、關鍵字參數,和第五種Python3新特性參數:僅限關鍵字參數。函數注解是一種元數據,存在__annotations__屬性中,備注函數的參數和返回值的類型,它只是個注解,

四種參數

Python函數func定義如下:

?
1
2
3
4
5
6
7
8
def func(first, *args, second="Hello World", **kwargs):
    print(first)
    print(args)
    print(second)
    print(kwargs)
 
 
func("dongfanger", "san", py="good")

運行后會輸出:

?
1
2
3
4
dongfanger
('san',)
Hello World
{'py': 'good'}

它有四種參數:

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

func函數的調用方式有以下這些:

①傳入單個定位參數。

?
1
func("dongfanger")
?
1
2
3
4
dongfanger
()
Hello World
{}

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

?
1
func("dongfanger", "a", "b", "c")
?
1
2
3
4
dongfanger
('a', 'b', 'c')
Hello World
{}

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

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

④second只能作為關鍵字參數傳入。

?
1
func("dongfanger", second="cool")
?
1
2
3
4
dongfanger
()
cool
{}

⑤定位函數也能作為關鍵字參數傳入。

?
1
func(first="san")
?
1
2
3
4
san
()
Hello World
{}

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

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

除了這四種參數,還有一種Python3新增加的僅限關鍵字參數。

僅限關鍵字參數

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

假如把參數位置調整一下定義another_func函數:

?
1
2
3
4
5
6
7
8
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")

輸出會變成:

?
1
2
3
4
dongfanger
# 注意這里
('b', 'c')
{}

another_second不是僅限關鍵字參數,而只是默認值參數,因為它捕獲到了定位參數。

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

還有第二個方法定義僅限關鍵字參數,在簽名中放一個*:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
>>> def f(a, *, b):  # b是僅限關鍵字參數
...    return a, b
...
>>> f(1, b=2# 只能傳關鍵字參數
(1, 2)
>>> f(1, 2# 不能傳定位參數
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# 不能傳定位參數
Traceback (most recent call last):
  File "<input>", line 1, in <module>
TypeError: f() takes 1 positional argument but 3 were given

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

內省中的函數參數

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

對于func函數:

?
1
2
3
4
5
def func(first, *args, second="Hello World", **kwargs):
    print(first)
    print(second)
    print(args)
    print(kwargs)

和another_func函數:

?
1
2
3
4
5
def another_func(first, another_second="Hello World", *args,  **kwargs):
    print(first)
    print(another_second)
    print(args)
    print(kwargs)

【__defaults__屬性】

元組,保存著定位參數和關鍵字參數的默認值。

?
1
2
3
print(func.__defaults__)  # None
 
print(another_func.__defaults__)  # ('Hello World',)

【__kwdefaults__屬性】

字典,保存僅限關鍵字參數。

?
1
2
3
print(func.__kwdefaults__)  # {'second': 'Hello World'}
 
print(another_func.__kwdefaults__)  # None

【__code__屬性】

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

?
1
2
3
print(func.__code__.co_varnames)  # ('first', 'second', 'args', 'kwargs')
 
print(another_func.__code__.co_varnames)  # ('first', 'another_second', 'args', 'kwargs')

另外還可以使用inspect庫的signature方法來查看內省中的函數參數:

?
1
2
3
4
from inspect import signature
 
print(signature(func)) 
# (first, *args, second='Hello World', **kwargs)

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

函數注解

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

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

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

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

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

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

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

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

以上就是Python函數參數和注解的使用的詳細內容,更多關于Python函數參數和注解的資料請關注服務器之家其它相關文章!

原文鏈接:https://www.cnblogs.com/df888/p/14634619.html

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 国产精品久久久久久久人人看 | 久久re这里精品在线视频7 | 美女一线天 | 日韩成人一区ftp在线播放 | 99久久精品6在线播放 | 精品久久久久久影院免费 | voyeur 中国女厕 亚洲女厕 | 亚洲波多野结衣日韩在线 | 久久国产精品人妻中文 | 特黄a大片免费视频 | 91寡妇天天综合久久影院 | 亚州中文字幕 | 极品蜜桃臀美女啪啪 | 99在线观看视频 | 成人精品一级毛片 | 忘忧草研究院一二三 | 啪啪导航 | 风间由美一区二区av101 | 国产精品亚洲片在线观看麻豆 | 色欧美在线 | 日本老熟老太hd | 国产激情视频网站 | 成人免费观看网欧美片 | 日本不卡在线一区二区三区视频 | 亚洲国产第一区二区三区 | 日本 视频 在线 | 午夜精品一区 | 国产一卡二卡3卡4卡四卡在线视频 | 果冻传媒在线视频观看免费 | 国产精品久久久久久久久久久久久久 | 亚洲成综合人影院在院播放 | 我与白丝同桌的故事h文 | 性bbbbwwbbbb| 日韩国产成人资源精品视频 | 亚洲狠狠婷婷综合久久蜜桃 | 第一次破学生处破 | 强漂亮白丝女教师小说 | 亚洲精品资源 | 高清女主播一区二区三区 | 日本熟hdx | 深夜激情网站 |