一篇文章帶你了解python中的typing模塊和類型注解
function annotation 寫法:
- 使用冒號
:
加類型代表參數(shù)類型- 默認值參數(shù)示例:
b: int = 2
- 默認值參數(shù)示例:
- 使用
->
加類型代表返回值類型
python解釋器運行時并不會檢查類型,類型不對也不會拋異常,僅僅是注解而已。示例:
def plus(a: int, b: int = 2) -> int: return a + b
python 解析器并不會在意類型注解,嚴格來說這是不對的,Python 會把類型信息放在 __annotations__
屬性中:
>>> def foo(a: str): ... print('hello', a) ... >>> foo.__annotations__ {'a': str} >>> class Bar: ... a: str ... b: int >>> Bar.__annotations__ {'a': str, 'b': int}
typing模塊
內(nèi)置提供的類型:int
、str
、float
,typing模塊提供的類型:Dict
、List
、Tuble
...
typing使用方括號 Dict[str, int]
而不是圓括號 Dict(str, int)
Dict
Dict[str, int]: 表示一個 keys 的類型為 str,values 的類型為 int 的字典,比如 {"a": 1, "b": 2}
from typing import Dict Dict[str, Dict[str, List[str]]]如下: { '原木鎮(zhèn)': { '第一小學': ['張偉', '王偉', '王芳'], '第二小學': ['李偉', '李娜'], }, '鴿子鎮(zhèn)': { '高山中學': ['張敏', '李靜'], '億百中學': ['王靜'] '蟒蛇小學': ['劉偉', '王秀英'] } }
List
List[int] 表示由整型組成的列表,比如[0, 1, 1, 2, 3]
List[List[int]] = [[1, 2], [2, 3]]
Tuple
Tuple[int, float, str] is a tuple of an int, a float and a string.
person: Tuple[str, int, float] = ('Mike', 22, 1.75)
set/AbstractSet
根據(jù)官方文檔,Set 推薦用于注解返回類型,AbstractSet 用于注解參數(shù)
def describe(s: AbstractSet[int]) -> Set[int]: return set(s)
Sequence
Sequence,是 collections.abc.Sequence 的泛型,在某些情況下,我們可能并不需要嚴格區(qū)分一個變量或參數(shù)到底是列表 list 類型還是元組 tuple 類型,我們可以使用一個更為泛化的類型,叫做 Sequence,其用法類似于 List
def square(elements: Sequence[float]) -> List[float]: return [x ** 2 for x in elements]
NoReturn
NoReturn,當一個方法沒有返回結(jié)果時,為了注解它的返回類型,我們可以將其注解為NoReturn
def hello() -> NoReturn: print('hello')
Any
Any,可以代表所有類型,所有的無參數(shù)類型注解和返回類型注解的都會默認使用 Any 類型,以下兩個函數(shù)等價:
def add(a): return a + 1 def add(a: Any) -> Any: return a + 1
TypeVar
TypeVar,自定義兼容特定類型的變量,比如有的變量聲明為 int、float、None 都是符合要求的,實際就是代表任意的數(shù)字或者空內(nèi)容都可以,其他的類型則不可以,比如列表 list、字典 dict 等等,像這樣的情況,我們可以使用 TypeVar 來表示。
height = 1.75 Height = TypeVar('Height', int, float, None) def get_height() -> Height: return height
NewType
newType,聲明一些具有特殊含義的類型,像 Tuple 的例子一樣,我們需要將它表示為 Person,即一個人的含義,但但從表面上聲明為 Tuple 并不直觀,所以我們可以使用 NewType 為其聲明一個類型,如:
Person = NewType('Person', Tuple[str, int, float]) person = Person(('Mike', 22, 1.75))
實際上 person 就是一個 tuple 類型,我們可以對其像 tuple 一樣正常操作。
Callable
Callable,可調(diào)用類型,通常用來注解一個方法, 在聲明的時候需要使用 Callable[[Arg1Type, Arg2Type, ...], ReturnType]
這樣的類型注解,將參數(shù)類型和返回值類型都要注解出來,例如:
def date(year: int, month: int, day: int) -> str: return f'{year}-{month}-{day}' def get_date_fn() -> Callable[[int, int, int], str]: return date
-> Callable[[int, int, int], str]: 中括號內(nèi)分別標記了返回的方法的參數(shù)類型和返回值類型。
Union
Union,聯(lián)合類型,Union[X, Y]
代表要么是 X 類型,要么是 Y 類型。
Union[Union[int, str], float] == Union[int, str, float] Union[int] == int Union[int, str, int] == Union[int, str] # 無參數(shù)順序 Union[int, str] == Union[str, int]
在一些方法參數(shù)聲明的時候比較有用,比如一個方法,要么傳一個字符串表示的方法名,要么直接把方法傳過來:
def process(fn: Union[str, Callable]): if isinstance(fn, str): # str2fn and process pass elif isinstance(fn, Callable): fn()
這樣的聲明在一些類庫方法定義的時候十分常見。
Optional
Optional,意思是說這個參數(shù)可以為空或已經(jīng)聲明的類型,即 Optional[X]
等價于 Union[X, None]
。
Optional 并不等價于可選參數(shù),當它作為參數(shù)類型注解的時候,不代表這個參數(shù)可以不傳遞,而是說這個參數(shù)可以傳None,不傳也會報錯。
當一個方法執(zhí)行結(jié)果,如果執(zhí)行完畢就不返回錯誤信息, 如果發(fā)生問題就返回錯誤信息,則可以這么聲明:
def judge(result: bool) -> Optional[str]: if result: return 'Error Occurred'
Generator
Generator,想代表一個生成器類型,可以使用 Generator,它的聲明比較特殊,其后的中括號緊跟著三個參數(shù),分別代表 YieldType、SendType、ReturnType,如:
def echo_round() -> Generator[int, float, str]: sent = yield 0 while sent >= 0: sent = yield round(sent) return 'Done'
在這里 yield 關(guān)鍵字后面緊跟的變量的類型就是 YieldType,yield 返回的結(jié)果的類型就是 SendType,最后生成器 return 的內(nèi)容就是 ReturnType。
當然很多情況下,生成器往往只需要 yield 內(nèi)容就夠了,我們是不需要 SendType 和 ReturnType 的,可以將其設(shè)置為空,如:
def infinite_stream(start: int) -> Generator[int, None, None]: while True: yield start start += 1
總結(jié)
本篇文章就到這里了,希望能夠給你帶來幫助,也希望您能夠多多關(guān)注腳本之家的更多內(nèi)容!
相關(guān)文章
Python Requests訪問網(wǎng)絡(luò)更方便
這篇文章主要介紹了使用Python Requests訪問網(wǎng)絡(luò),Python Requests 是一個非常強大的 HTTP 客戶端庫,用于發(fā)送 HTTP 請求,獲取響應(yīng)等操作,通過這個庫,你可以輕松地與 Web 服務(wù)進行交互,實現(xiàn)各種網(wǎng)絡(luò)請求2024-01-01PyCharm如何設(shè)置Console控制臺輸出自動換行
這篇文章主要介紹了PyCharm如何設(shè)置Console控制臺輸出自動換行問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-05-05Python正則表達式高效處理文本數(shù)據(jù)的秘訣輕松掌握
當談到文本處理和搜索時,正則表達式是Python中一個強大且不可或缺的工具,正則表達式是一種用于搜索、匹配和處理文本的模式描述語言,可以在大量文本數(shù)據(jù)中快速而靈活地查找、識別和提取所需的信息,2023-11-11aws 通過boto3 python腳本打pach的實現(xiàn)方法
這篇文章主要介紹了aws 通過boto3 python腳本打pach的實現(xiàn)方法,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-05-05Python實現(xiàn)圖片指定位置加圖片水?。ǜ絇yinstaller打包exe)
這篇文章主要介紹了Python實現(xiàn)圖片指定位置加圖片水印,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2021-03-03