Python-typing: 類型標(biāo)注與支持 Any類型詳解
Any 是一種特殊的類型。
靜態(tài)類型檢查器將所有類型視為與 Any 兼容,反之亦然, Any 也與所有類型相兼容。
這意味著可對(duì)類型為 Any 的值執(zhí)行任何操作或方法調(diào)用,并將其賦值給任何變量:
from typing import Any
a = None # type: Any
a = [] # OK
a = 2 # OK
s = '' # type: str
s = a # OK
def foo(item: Any) -> int:
# Typechecks; 'item' could be any type,
# and that type might have a 'bar' method
item.bar()
...
需要注意的是,將 Any 類型的值賦值給另一個(gè)更具體的類型時(shí),Python不會(huì)執(zhí)行類型檢查。例如,當(dāng)把 a 賦值給 s 時(shí),即使 s 被聲明為 str 類型,在運(yùn)行時(shí)接收到的是 int 值,靜態(tài)類型檢查器也不會(huì)報(bào)錯(cuò)。
此外,所有返回值無類型或形參無類型的函數(shù)將隱式地默認(rèn)使用 Any 類型:
def legacy_parser(text):
...
return data
# A static type checker will treat the above
# as having the same signature as:
def legacy_parser(text: Any) -> Any:
...
return data
當(dāng)需要混用動(dòng)態(tài)類型和靜態(tài)類型的代碼時(shí),上述行為可以讓 Any 被用作 應(yīng)急出口 。
Any 和 object 的行為對(duì)比。
與 Any 相似,所有的類型都是 object 的子類型。然而不同于 Any,反之并不成立: object 不是 其他所有類型的子類型。
這意味著當(dāng)一個(gè)值的類型是 object 的時(shí)候,類型檢查器會(huì)拒絕對(duì)它的幾乎所有的操作。把它賦值給一個(gè)指定了類型的變量(或者當(dāng)作返回值)是一個(gè)類型錯(cuò)誤。
比如說:
def hash_a(item: object) -> int:
# Fails; an object does not have a 'magic' method.
item.magic()
...
def hash_b(item: Any) -> int:
# Typechecks
item.magic()
...
# Typechecks, since ints and strs are subclasses of object
hash_a(42)
hash_a("foo")
# Typechecks, since Any is compatible with all types
hash_b(42)
hash_b("foo")
使用 object 示意一個(gè)值可以類型安全地兼容任何類型。使用 Any 示意一個(gè)值地類型是動(dòng)態(tài)定義的。
補(bǔ)充:python3.5 typing — 類型標(biāo)注支持
函數(shù)接受并返回一個(gè)字符串,注釋像下面這樣:
def greeting(name: str) -> str:
return 'Hello' + name
在函數(shù) greeting 中,參數(shù) name 預(yù)期是 str 類型,并且返回 str 類型。子類型允許作為參數(shù)。
1.1. 類型別名
型別名通過將類型分配給別名來定義。在這個(gè)例子中, Vector 和 List[float] 將被視為可互換的同義詞:
from typing import List
Vector = List[float]
def scale(scalar: float, vector: Vector) -> Vector:
return [scalar * num for num in vector]
# typechecks; a list of floats qualifies as a Vector.
new_vector = scale(2.0, [1.0, -4.2, 5.4])
類型別名可用于簡(jiǎn)化復(fù)雜類型簽名。
例如:
from typing import Dict, Tuple, List
ConnectionOptions = Dict[str, str]
Address = Tuple[str, int]
Server = Tuple[Address, ConnectionOptions]
def broadcast_message(message: str, servers: List[Server]) -> None:
...
# The static type checker will treat the previous type signature as
# being exactly equivalent to this one.
def broadcast_message(
message: str,
servers: List[Tuple[Tuple[str, int], Dict[str, str]]]) -> None:
...
請(qǐng)注意,None 作為類型提示是一種特殊情況,并且由 type(None) 取代。
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教。
相關(guān)文章
python利用beautifulSoup實(shí)現(xiàn)爬蟲
這篇文章主要介紹了python利用beautifulSoup實(shí)現(xiàn)爬蟲,需要的朋友可以參考下2014-09-09
Python實(shí)現(xiàn)常見限流算法的示例代碼
在系統(tǒng)的穩(wěn)定性設(shè)計(jì)中,需要考慮到的就是限流,避免高并發(fā)環(huán)境下一下子把服務(wù)整垮了,本文為大家整理了一些Python實(shí)現(xiàn)的常見限流算法,希望對(duì)大家有所幫助2024-03-03
如何用Python來理一理紅樓夢(mèng)里的那些關(guān)系
這篇文章主要介紹了用Python來理一理紅樓夢(mèng)里的那些關(guān)系代碼實(shí)例,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-08-08
對(duì)Python 3.2 迭代器的next函數(shù)實(shí)例講解
今天小編就為大家分享一篇對(duì)Python 3.2 迭代器的next函數(shù)實(shí)例講解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2018-10-10
用python實(shí)現(xiàn)讀取xlsx表格操作
大家好,本篇文章主要講的是用python實(shí)現(xiàn)讀取xlsx表格操作,感興趣的同學(xué)趕快來看一看吧,對(duì)你有幫助的話記得收藏一下2022-01-01
Python實(shí)現(xiàn)端口復(fù)用實(shí)例代碼
這篇文章主要介紹了Python實(shí)現(xiàn)端口復(fù)用實(shí)例代碼,需要的朋友可以參考下2014-07-07
基于Python+Flask設(shè)計(jì)實(shí)現(xiàn)AI智能天氣助手系統(tǒng)
這篇文章主要為大家詳細(xì)介紹了如何基于Python和Flask設(shè)計(jì)實(shí)現(xiàn)一個(gè)AI智能天氣助手系統(tǒng),文中的示例代碼講解詳細(xì),感興趣的小伙伴可以參考一下2025-03-03

