python 編碼中為什么要寫類型注解?
我們先談?wù)劄槭裁丛赑ython編碼過程中強烈推薦使用類型注解 ?
Python對于初學(xué)者來說是非常好上手,原因是在于對計算機底層原理的高度封裝和動態(tài)語言的特性使得Python用起來非常的舒適。但這種“舒適”是有代價的,我們可能聽說過一句形容動態(tài)語言的話,動態(tài)一時爽,一直動態(tài)一直爽。為什么會這么說?動態(tài)的確會賦予我們在編碼時更多的靈活性與能力,但是動態(tài)帶來的是更多的不確定性及混亂,導(dǎo)致了后來的維護者甚至作者自己都會產(chǎn)生很大的維護壓力(可以想象一個經(jīng)過幾年迭代的復(fù)雜系統(tǒng),如果大部分都使用動態(tài)的方式來編寫代碼的樣子),正所謂能力越大責(zé)任越大,需要進行克制;
而類型注解能很好的幫我們在維護與開發(fā)時,理清變量類型降低不確定性和混亂度,并且從容的使用變量。在這里廢話了這么多,主要是為了能讓讀者能深刻意識到動態(tài)帶來的正反方向帶來的“爽”。后面進入正題;
2、使用方式2.1、 Python3內(nèi)置的類型注解內(nèi)置注解肯能大家都接觸過,但總感覺很麻煩,導(dǎo)致后面很容易就放棄寫注解,這是因為得到不正反饋,看如下示例:
a: str = 'aa'b: int = 1# 參數(shù)和返回標注了類型,那么接下來調(diào)用時就能進行提示def example(a: str) -> str: return f'Hello {a}'pirnt(example('world'))# # 一些簡單的標注,看起來起不到效果,但如果換個有含義的名字呢User = strAge = intAnswer = strdef say_hello(u: User) -> Answer: return f'Hello {u}'print(say_hello('Shadow'))
上面簡單演示了內(nèi)置的類型注解是如何使用的,但是其實這么簡單的類型注解并不能幫助我們很好的標注變量;下面介紹一個typing模塊
2.2、typing 模塊的快速入門typing 模塊是類型注解的主角,Python運行時不強制執(zhí)行函數(shù)和變量類型注解,但這些注解可用于類型檢查器、IDE、靜態(tài)檢查器等第三方工具。這些第三方工具會在我們編碼時進行提示與糾錯;
下面提供一些日常使用到的方法與用例給大家參考:
import typing# 自定義類型注解User = strAge = int# 定義有多種類型注解的類型AnyStr = typing.TypeVar(’AnyStr’, str, bytes)a_str: AnyStr = 'a'a_bytes: AnyStr = b'a'# 通用類型, 接收通用的類型,盡量少的去使用def example_1(a: typing.Any): print(a)'''typing 模塊是允許使用下標來輔助標記類型'''# 列表, 下標為列表的屬性def example_2(a_list: typing.List[User]) -> typing.List[str]: pass# 字典,下標第一個為key,第二個為valuedef example_3(a_dict: typing.Dict[User, Age]) -> typing.Dict[str, int]: pass# 元祖,下標為元祖的屬性def example_4(a_tuple: typing.Tuple[User] = None) -> typing.Tuple[User]: pass# Union, 在一些場景下我們某些參數(shù)或返回值是不確定,至少給定一個參數(shù)類型def example_5(a_b: typing.Union[str, int]) -> typing.Union[str, int]: pass# Optional, 與Union 有點類似,但默認多帶一個None,至少給定一個參數(shù)類型# 如:Optional[str] 等價于 Union[str, None]def example_6(a: str) -> typing.Optional[str]: pass# Tuple, 返回值有多個的時候, 如需要返回str, int, bool, floatdef example_7() -> typing.Tuple[str, int, bool, float]: pass# class, 類本身也是一種類型class Action: up: str = 'up' down: str = 'down'# 指定需求一個action對象的參數(shù)def example_8(action_obj: Action) -> Action: pass# 這樣在一些枚舉參數(shù)的場景下,我們也可以使用類作為我們枚舉參數(shù)的歸類def example_9(action_cls: Action) -> Action: pass# 如果上面的枚舉參數(shù)你覺得并不能很好的實現(xiàn),那么還是可以使用自定義類型注解的方式去實現(xiàn)Action = strup: Action = 'up'down: Action = 'down'# 在python3.9 中對枚舉參數(shù)類型有更好的支持MODE = type.Literal[’r’, ’rb’, ’w’, ’wb’]def open_file(file: str, mode: MODE) -> str: passopen_file(’/some/path’, ’r’) # 正常open_file(’/other/path’, ’typo’) # 會提示該類型不合法# Type, 在一些多態(tài)類的場景下標注同一個類型的不同的形態(tài)class User: ...class BasicUser(User): ...class ProUser(User): ...class TeamUser(User): ...# 相當(dāng)于 typing.Union[User, BasicUser, ProUser, TeamUser]def make_new_user(user_class: typing.Type[User]) -> User: return user_class()
以上十幾個用例場景基本能覆蓋大部分日常編碼,如果還有一些別的需求可參考官方的文檔,上面有明確的說明;
Docs: docs.python.org/zh-cn/3/lib…
3、寫在最后希望文章能對大家對類型注解的了解與使用有所幫助,早日脫離被動態(tài)繞得心里“罵娘”與找不到'娘'的日子。
以上就是python 編碼中為什么要寫類型注解?的詳細內(nèi)容,更多關(guān)于python 類型注解的資料請關(guān)注好吧啦網(wǎng)其它相關(guān)文章!
相關(guān)文章:
1. ASP 信息提示函數(shù)并作返回或者轉(zhuǎn)向2. asp(vbs)Rs.Open和Conn.Execute的詳解和區(qū)別及&H0001的說明3. CSS hack用法案例詳解4. PHP設(shè)計模式中工廠模式深入詳解5. 用css截取字符的幾種方法詳解(css排版隱藏溢出文本)6. ASP+ajax實現(xiàn)頂一下、踩一下同支持與反對的實現(xiàn)代碼7. .NET中l(wèi)ambda表達式合并問題及解決方法8. ThinkPHP5實現(xiàn)JWT Token認證的過程(親測可用)9. asp中response.write("中文")或者js中文亂碼問題10. JSP數(shù)據(jù)交互實現(xiàn)過程解析
