點選上方“機器學習與生成對抗網絡”,關注"星标"
擷取有趣、好玩的前沿幹貨!
作者 | Ayushi Rawat 整理自 python遇見機器學習
Python一直在滿足社群需求,并且将成為未來使用最多的語言。
Python的下一個版本帶來了更快速的程序釋放,性能的提升,簡便的新字元串函數,字典并集運算符以及更相容穩定的内部API。
文章将涉及:
- 字典并集和可疊代更新
- 字元串方法
- 類型提示
- 新的數學函數
- 新的解析器
- IPv6範圍内的位址
- 新子產品:區域資訊
- 其他語言更改
字典并集和可疊代更新
字典并集
我最喜歡的新特性之一是流暢的文法。
Python 3.9 dict類。如果有兩個字典a和b,則現在可以使用這些運算符進行合并和更新。
我們有合并運算符|:

還有更新運算符| =,它會更新原始字典:
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類型之間的并集。
字元串方法
removeprefix()和removesuffix()
str.removeprefix(substring:string)字元串方法:如果str以它開頭的話,将會傳回一個修改過字首的新字元串,否則它将傳回原始字元串。
str.removesuffix(substring:string)字元串方法:如果str以其結尾,則傳回帶有修改過字尾的新字元串,否則它将傳回原始字元串。
這兩個函數執行的操作将使用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實作。
其他變化
__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論文梳理彙總!
附下載下傳 |《計算機視覺中的數學方法》分享