天天看點

關于Python 3.9,那些你不知道的事

點選上方“機器學習與生成對抗網絡”,關注"星标"

擷取有趣、好玩的前沿幹貨!

作者 | Ayushi Rawat 整理自 python遇見機器學習

Python一直在滿足社群需求,并且将成為未來使用最多的語言。

Python的下一個版本帶來了更快速的程序釋放,性能的提升,簡便的新字元串函數,字典并集運算符以及更相容穩定的内部API。

文章将涉及:

  • 字典并集和可疊代更新
  • 字元串方法
  • 類型提示
  • 新的數學函數
  • 新的解析器
  • IPv6範圍内的位址
  • 新子產品:區域資訊
  • 其他語言更改

字典并集和可疊代更新

字典并集

我最喜歡的新特性之一是流暢的文法。

Python 3.9 dict類。如果有兩個字典a和b,則現在可以使用這些運算符進行合并和更新。

我們有合并運算符|:

關于Python 3.9,那些你不知道的事

還有更新運算符| =,它會更新原始字典:

a = {1: 'a', 2: 'b', 3: 'c'}b = {4: 'd', 5: 'e'}a |= bprint(a){1: 'a', 2: 'b', 3: 'c', 4: 'd', 5: 'e'}
           

如果我們的詞典共享一個公用密鑰,那麼第二個詞典中的鍵值對将會被使用:

a = {1: 'a', 2: 'b', 3: 'c', 6: 'in both'}b = {4: 'd', 5: 'e', 6: 'but different'}print(a | b){1: 'a', 2: 'b', 3: 'c', 6: 'but different', 4: 'd', 5: 'e'}
           

使用Iterables進行字典更新

| =運算符的另一個很棒的性能是能夠使用可疊代對象(如清單或生成器)用新的鍵值對來更新字典:

a = {'a': 'one', 'b': 'two'}b = ((i, i**2) for i in range(3))a |= bprint(a){'a': 'one', 'b': 'two', 0: 0, 1: 1, 2: 4}
           

如果我們嘗試使用标準的并集運算符|,則會提示類型錯誤,因為它僅允許dict類型之間的并集。

關于Python 3.9,那些你不知道的事

字元串方法

removeprefix()和removesuffix()

str.removeprefix(substring:string)字元串方法:如果str以它開頭的話,将會傳回一個修改過字首的新字元串,否則它将傳回原始字元串。

str.removesuffix(substring:string)字元串方法:如果str以其結尾,則傳回帶有修改過字尾的新字元串,否則它将傳回原始字元串。

關于Python 3.9,那些你不知道的事

這兩個函數執行的操作将使用string [len(prefix):]作為字首,string [:-len(suffix)]作為字尾。

這些是非常簡單的操作,是以實作的也是非常簡單的功能,但是考慮到可能會經常執行這些操作,最好有一個内置的函數可以完成此操作。

類型提示

Python是動态類型的,動态地為變量指定資料類型,意味着我們無需在代碼中指定資料類型。

但有時可能會造成混淆!

對于資料類型的靜态配置設定,通常使用類型提示。這是在Python 3.5中引入的。從3.5開始,我們可以指定類型,但這是比較麻煩的。

這項更新真正改變了這一點,現在可以将内置集合類型(List和Dict)用作泛型類型。

之前,必須通過輸入來調用大寫類型List和Dict。

ef greet_all(names: list[str]) -> None:for name in names:print("Hello", name)
           

現在,無需從typing.List來調用List

新的數學函數

數學子產品添加和改進了許多輔助功能,從對現有功能的改進開始。

import math#Greatest common divisormath.gcd(80, 64, 152)#8
           

以前計算最大公因數的gcd函數隻能應用于2個數字,迫使程式員在處理更多數字時必須執行類似math.gcd(80,math.gcd(64,152))的操作。從Python 3.9開始,我們可以将其應用于任意數字的值。

math子產品中第一個新添加的是math.lcm函數:

#Least common multiplemath.lcm(4, 8, 5)#40
           

math.lcm計算其參數的最小公倍數。與GCD一樣,它允許可變數量的參數。

新解析器

這部分更多是視線之外的改變,但有可能成為Python未來發展中最重大的改變之一。

Python 3.9使用了一個新的基于PEG的解析器。以前Python使用LL(1),在建構該語言的新功能時,PEG比LL(1)更靈活。官方文檔中表示,這種靈活性将在Python 3.10及更高版本中展現出來。

ast子產品使用新的解析器,并産生與舊解析器相同的AST。

IPv6範圍的位址

Python 3.9的另一個變化是可以指定IPv6位址的範圍。IPv6範圍用于指定相應IP位址在Internet的哪個部分有效。

範圍可以使用%符号在IP位址的末尾指定——例如:3FFE:0:0:1:200:F8FF:FE75:50DF%2——是以該IP位址在範圍2中,即連結本地位址。

是以,如果需要使用Python處理IPv6位址,現在可以這樣處理:

from ipaddress import IPv6Addressaddr = IPv6Address('ff02::fa51%1')print(addr.scope_id)#"1" - interface-local IP address
           

注意使用基本的Python運算符進行比較時,兩個具有不同範圍的位址是不相同的。

新子產品

區域資訊

zoneinfo子產品将IANA時區資料庫的支援引入标準庫。它添加了zoneinfo.ZoneInfo,這是一個由系統時區資料支援的具體的datetime.tzinfo實作。

關于Python 3.9,那些你不知道的事

其他變化

__import __()現在增加了ImportError以替代ValueError,通常在相對導入超出其頂級包時發生。

“” .replace(“”,s,n)現在對于所有非零n傳回s而不是空字元串。現在它與““ .replace(”“,s)相一緻。

預設狀态下,Python變得更快

Python的每個修訂版與以前的版本相比都有性能改進。Python 3.9進行了兩項重大改進,可以提高性能但無需對現有代碼進行任何更改。

第一個改進更多涉及矢量調用協定的使用,通過最小化或消除臨時對象進行許多常見函數的調用。Python 3.9引入了幾個新的内置函數,包括range、tuple、set、frozenset、list、dict ——使用vectorcall可以加快執行速度。

Python切換到年度釋出周期

到目前為止,Python已經以18個月的節奏進行了開發和釋出。PEP 602提議Python開發團隊采用年度釋出周期,并且該提議已被接受。

結語

随着每個新版本的釋出,Python都變得越來越快速和強大,操作常見的資料類型也變得越來越簡單。

可能并不是所有這些更改都與大家的日常程式設計相關,但是我認為至少要意識到這是一件好事,因為它們可能會在某些時候派上用場。

資源

python.org/downloads/release/python-390a5

docs.python.org/3.9/whatsnew/3.9.html

猜您喜歡:
附下載下傳 | 《Python進階》中文版
附下載下傳 | 經典《Think Python》中文版
附下載下傳 | 《Pytorch模型訓練實用教程》
附下載下傳 | 最新2020李沐《動手學深度學習》

附下載下傳 | 《可解釋的機器學習》中文版

附下載下傳 |《TensorFlow 2.0 深度學習算法實戰》

附下載下傳 | 超100篇!CVPR 2020最全GAN論文梳理彙總!
附下載下傳 |《計算機視覺中的數學方法》分享