Python基礎-24 類型標註

来源:https://www.cnblogs.com/surpassme/archive/2022/08/03/16545609.html
-Advertisement-
Play Games

24 類型標註 24.1 Python中的數據類型 在Python中有很多數據類型,比較常見如下所示: |整型 | 浮點型|字元串 | 列表|元組|字典|集合|布爾| | | | | | | | | | |int| float|str|list|tuple|dict|set|bool| 因Pytho ...


24 類型標註

24.1 Python中的數據類型

    在Python中有很多數據類型,比較常見如下所示:

整型 浮點型 字元串 列表 元組 字典 集合 布爾
int float str list tuple dict set bool

    因Python是弱類型語言,所以在實際寫代碼時,一般不去聲明定義參數的類型。示例如下:

def welcome(city):
   print(f"welcome to {city}")

    以上代碼非常簡單,就是輸出一行歡迎標語。而在大家看到這個代碼,也都預設了city是一個字元串類型(str)。

    現在我們來改造一下代碼,將傳入的city參數全部變為大寫,代碼如下所示:

def welcome(city):
   print(f"welcome to {city.upper()}")

以上代碼在傳入的city為字元串類型時,一切正常,但如果傳入的是非字元串類型就會報錯,例如傳入123,便會出現如下所示的報錯

AttributeError: 'int' object has no attribute 'upper'

24.2 指定類型

24.2.1 指定變數類型

24.2.1.1 指定變數類型

    針對以上問題,Python 3.5中引入了typing包,推薦使用類型標註,並且IDE會檢查類型,讓Python看起來有點像靜態語言的感覺。

    那如何指定變數類型呢?只需要在變數名後 :類型 即可,如下所示:

def welcome(city:str):
   print(f"welcome to {city.upper()}")
24.2.1.2 變數類型聲明的好與壞

    變數類型聲明,對於之前有使用過強類型語言的人來講,可能習以為常。但卻對弱類型的語言,可能不太習慣,但確實還是有一些好處的。

  • 以上面代碼為例,如果定義為str類型,而實際傳入為int時,PyCharm會進行相應的提示,不能這樣做,如下所示:

  • PyCharm會有更多提示

    在Python中,str類型的數據會有很多方法,而在指定數據類型後,PyCharm則會有更多提示,如下所示:

  • 閱讀代碼方便,可以更快的知道需要傳入什麼類型的數據及返回的數據類型

    在指定變數的數據類型時,也是有一些壞處的,如下所示:

  • 在編寫代碼,需要多寫一些代碼,看起來沒有那麼流暢
  • 雖然指定的數據類型,但也僅僅是方便查看,並沒有規定死變數類型,如指定為str類型,但傳入int,依然可以運行代碼,沒有在運行層面進行檢查

24.2.2 指定返回值類型

    在Python裡面,方法/函數都是有返回值的,那麼使用類型標的話,可以直接方法/函數末尾冒號之前添加 ->類型,示例如下所示:

def welcome(city:str)->str:
   return city.upper()

    這樣做的好處跟之前示例一樣,IDE可以更加智能提示,防止編寫代碼出錯,如下所示:

    指定類型並不會影響編譯結果,但也有很多好處,如下所示:

  • 提高開發效率
  • 降低出錯率
  • 閱讀代碼更友好

24.3 typing包

24.3.1 typing作用

    主要作用如下所示:

  • 類型檢查,防止運行時出現參數和返回值類型不符合
  • 做為開發文檔附加說明,方便調用者快速查看傳入和返回數據類型
  • 加入該模塊後,不影響程式運行,僅有提醒

typing模塊只有在Python 3.5 以上版本中才可以使用,PyCharm支持typing檢查

24.3.2 typing包常見數據類型

類型 備註
int int
str str
List 列表,也可以使用list
List[類型] 指定列表中存放的數據類型
Tuple 元組,也可以使用tuple
Tuple[類型] 指定元組中存放的數據類型
Set 集合,也可以使用set
Set[類型] 指定集合中存放的數據類型
Dict 字典,也可以使用dict
Dict[類型1,類型2] key為類型1,value為類型2的字典
Sequence[類型] 指定序列中存放的數據類型
NoReturn 表示無返回類型
Any 任意類型
TypeVar 自定義相容特定類型的變數
Union[類型1,類型2] 聯合類型,可以接受類型1或類型2
Optional[類型] 參數可以為空或已經聲明的類型

常見的類型如上表格表示,如果需要使用List,Set,Dict,Union則需要導入typing

from typing import List,Set,Dict

24.3.3 typing包常見數據類型用法

  • List

    List:列表,是list的泛型,基本等同於list,其後緊跟一個方括弧,裡面代表了構成這個列表的元素類型,示例如下所示:

from typing import List

# 基本聲明
listSample:List[int or str]=[1,"Surpass"]
# 嵌套聲明
listSample:List[List[int]]=[[1,2],[3,4]]
  • Tuple

    Tuple:元組,是 tuple 的泛型,其後緊跟一個方括弧,方括弧中按照順序聲明瞭構成本元組的元素類型,如 Tuple[X, Y] 代表了構成元組的第一個元素是 X 類型,第二個元素是 Y 類型,示例如下所示:

from typing import Tuple

personInfo:Tuple[str,int,float,str]=("Surpass",28,62.33,"Shanghai")
  • Set/AbstractSet

    Set(集合)是set 的泛型,AbstractSet是 collections.abc.Set 的泛型。根據官方文檔,Set 推薦用於註解返回類型,AbstractSet 用於註解參數,使用方法是後面跟一個中括弧,裡面聲明集合中元素的類型,示例如下所示:

from typing import Set,AbstractSet

def SetSample(s:AbstractSet[int]) -> Set[int]:
    return  set(s)
  • Dict/Mapping

    Dict(字典)是 dict 的泛型,Mapping(映射)是 collections.abc.Mapping 的泛型。根據官方文檔,Dict推薦用於註解返回類型,Mapping 推薦用於註解參數。使用方法都是其後跟一個中括弧,中括弧內分別聲明鍵名、鍵值的類型,示例如下所示:

from typing import Dict,Mapping

def DictSample(personInfo:Mapping[str,str])->Dict[str,str]:
    return {"name":personInfo["name"],"location":personInfo["location"]}
  • Sequence

    Sequence是 collections.abc.Sequence 的泛型,在某些情況下,我們可能並不需要嚴格區分一個變數或參數到底是列表類型還是元組類型,則可以使用一個更為泛化的類型,叫做 Sequence,其用法類似於List,示例如下所示:

from typing import Sequence,List

def Square(ele:Sequence[int])->List[int]:
    return [i**2 for i in ele]
  • NoReturn

    當一個方法沒有返回結果時,為了註解它的返回類型,我們可以將其註解為 NoReturn,示例如下所示:

from typing import NoReturn

def hello(word:str)->NoReturn:
    print(word.title())
  • Any

    Any是一種特殊的類型,它可以代表所有任意類型,靜態類型檢查器的所有類型都與 Any 類型相容,所有的無參數類型註解和返回類型註解的都會預設使用 Any 類型。以下示例兩種是完全等價相同的

from typing import Any

def hello(word):
    return word.title()

def hello(word:Any)->Any:
    return word.title()
  • TypeVar

    TypeVar可以用來自定義相容特定類型的變數,比如有的變數聲明為int、float、str都是符合要求的,實際就是代表任意的數字或者字元串都是可以的,其他的類型則不可以。例如一個人的身高,便可以使用 int 或 float 或 None 來表示,但不能用 dict 來表示,所以可以這麼聲明:

from typing import TypeVar

Height=TypeVar(int,float,None)

def getHeight(height)->Height:
    return height
  • NewType

    NewType,我們可以藉助於其來聲明一些具有特殊含義的類型,如前面Tuple示例,需要用來定義一個Person信息,但從錶面上聲明為Tuple不太直觀,因此可以藉助NewType來進行聲明。示例如下所示:

from typing import NewType,Tuple

personInfo=NewType("PersonInfo",Tuple[str,int,float,str])

person=personInfo(("Surpass",28,62.33,"Shanghai"))

示例中person就是一個tuple類型,跟其他tuple類型一樣進行操作

  • Union

    Union(聯合類型),Union[類型1,類型2] 代表要麼是類型1類型,要麼是類型2 類型。聯合類型的聯合類型等價於展平後的類型:

Union[Union[int, str], float] == Union[int, str, float]

    僅有一個參數的聯合類型等同於參數自身,示例如下:

Union[int] == int

    如果存在相同類型的時候,則會進行去重處理,示例如下:

Union[int, str, int] == Union[int, str]

    在比較聯合類型的時候,參數順序會被忽略,示例如下:

Union[int, str] == Union[str, int]
from typing import Union

def getType(params:Union[int,str,float])->str:
    if isinstance(params,int):
        return f"{params} type is int"
    elif isinstance(params,float):
        return f"{params} type is float"
    elif isinstance(params,str):
        return f"{params} type is str"
    else:
        return f"{params} type is unknown"
  • Optional

    Optional意思是說這個參數可以為空或已經聲明的類型,即 Optional[類型1] 等價於 Union[類型1, None]

需要註意的是這個並不等價於可選參數,當它作為參數類型註解的時候,不代表這個參數可以不傳遞了,而是說這個參數可以傳為 None。

from typing import Optional

def getInfo(data:Optional[int])->Optional[str]:
    if isinstance(data,int):
        return f"INFO - {data} type is int"
    elif data is None:
        return f"WARNING -  {data} type is None"
    else:
        return f"ERROR - {data} type is not int,"

原文地址:https://www.jianshu.com/p/5b135f8dec0d

本文同步在微信訂閱號上發佈,如各位小伙伴們喜歡我的文章,也可以關註我的微信訂閱號:woaitest,或掃描下麵的二維碼添加關註:

作者: Surpassme

來源: http://www.jianshu.com/u/28161b7c9995/

         http://www.cnblogs.com/surpassme/

聲明:本文版權歸作者所有,歡迎轉載,但未經作者同意必須保留此段聲明,且在文章頁面明顯位置給出 原文鏈接 ,否則保留追究法律責任的權利。如有問題,可發送郵件 聯繫。讓我們尊重原創者版權,共同營造良好的IT朋友圈。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • Date日期 日期對象的定義(使用new關鍵詞) 1.獲取當前的時間(本地的時間) var date = new Date() //不傳參就是獲取當前時間 2.獲取指定的時間 var date = new Date(123456) //一個參數毫秒值 將這個毫秒值去加上對應的1970.1.1 0:0 ...
  • 今天在做css定位的時候遇到一個問題,我想用fixed定位下來,但是發現這個時候定義的百分百寬度不隨著父元素走了而是整個屏幕的百分百,這個就很尷尬了,也不能固定寬度吧,畢竟還要寬度自適應。 這個時候發現了一個position的屬性 sticky 它是relative和fixed的結合體可以理解為,當 ...
  • 最近,在對公司的一個老項目進行優化調整。有個使用的三方插件報表頁面,一旦查詢時間過長就會自動異常並使瀏覽器崩潰,由於這個插件只有個前人遺留的dll文件,實在看不懂裡面的代碼無從下手,既然項目前端大部分是基於EasyUI做的,想著就直接用EasyUI的DataGrid做數據報表明細展示。 由於之前很少 ...
  • 網頁是一個頁面,網站是由多個網頁組成的! 我們在使用代碼編寫的時候能看到這樣的東西,具體內容如下,比較基礎: 認識SEO? SEO就是搜索引擎優化,作用就是你找查找相關內容時,能夠優先給你展示這個內容。 SEO三大標簽(一般由想乾人員提供): title(網頁標簽)、description(網頁描述 ...
  • 項目背景 我們的系統(一個 ToB 的 Web 單頁應用)前端單頁應用經過多年的迭代,目前已經累積有大幾十萬行的業務代碼,30+ 路由模塊,整體的代碼量和複雜度還是比較高的。 項目整體是基於 Vue + TypeScirpt,而構建工具,由於最早項目是經由 vue-cli 初始化而來,所以自然而然使 ...
  • 什麼時候精靈圖呢? 通常在渲染頁面的時候,需要伺服器向我們發送數據,但有的時候一個頁面需要多張圖時,伺服器就會處於連續發圖的工作狀態,但如果我們把需要的圖都放在一張圖上,這樣可以大大的減少服務的工作負擔,打個比喻。伺服器發一張圖是,工作流程是:找到圖片——讀取圖片——發送圖片,如果是發送5個圖片時, ...
  • 蒼穹之邊,浩瀚之摯,眰恦之美; 悟心悟性,善始善終,惟善惟道! —— 朝槿《朝槿兮年說》 寫在開頭 我們都知道,經過多年的發展和無數Java開發者的不懈努力,Java已經由一門單純的電腦編程語言,逐漸演變成一套強大的以及仍在可持續發展中的技術體系平臺。 雖然,Java設計者們根據不同的技術規範,把 ...
  • 1. 登錄用戶數據獲取 登錄成功之後,在後續的業務邏輯中,開發者可能還需要獲取登錄成功的用戶對象,如果不使用任何安全管理框架,那麼可以將用戶信息保存在HttpSession中,以後需要的時候直接從HttpSession中獲取數據。在Spring Security中,用戶登錄信息本質上還是保存在 Ht ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...