1.詞典聯(lián)合運算符
這是我最喜歡的功能之一,語法非常優(yōu)美。
在Python3.9,如果你有兩個詞典,現(xiàn)在可以用這些運算符進行合并和更新。
合并運算符 "|":
還有update運算符|=
,它會更新原始字典:
a = {1: 'a', 2: 'b', 3: 'c'}
b = {4: 'd', 5: 'e'}
a |= b
print(a)
{1: 'a', 2: 'b', 3: 'c', 4: 'd', 5: 'e'}
如果我們的詞典共享一個key,那么將使用第二個詞典中的value:
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'}
使用可迭代對象進行字典更新
|=
操作符的另一個很酷的特性是能夠使用可迭代對象(例如列表或生成器)使用新的鍵值對更新字典:
a = {'a': 'one', 'b': 'two'}
b = ((i, i**2) for i in range(3))
a |= b
print(a)
{'a': 'one', 'b': 'two', 0: 0, 1: 1, 2: 4}
當然,如果你用|
這樣做,則會得到 TypeError ,因為它只能用于dict類型之間的聯(lián)合。
2.字符串方法
removeprefix() 和 removesuffix()
** str.removeprefix(substring: string)
**接收一個 substring 參數(shù),顧名思義,它將刪除字符串對應(yīng)的 substring 前綴,如果沒有對應(yīng)的前綴,返回原字符串。
** str.removesuffix(substring: string)
**接收一個 substring 參數(shù),它將刪除字符串的對應(yīng) substring 后綴,如果沒有對應(yīng)的后綴,返回原字符串。
當然,這兩個函數(shù)你也可以通過使用 **string[:-len(suffix)]
和string[len(prefix):]
**來實現(xiàn)。
這些是非常簡單的操作,因此也是非常簡單的功能,考慮到你可能經(jīng)常執(zhí)行這些操作,Python3.9 提供的這兩個內(nèi)置函數(shù)應(yīng)該能讓你非常爽。
3.新的數(shù)學(xué)函數(shù)
Python 3.9 的數(shù)學(xué)模塊進行了不少的優(yōu)化并添加了許多新功能。
比如以前gcd計算最大公因數(shù)的函數(shù)只能應(yīng)用于2個數(shù)字,這就很蛋疼,我們必須使用 ** math.gcd(80, math.gcd(64, 152))
**來處理大于2個數(shù)字的情況。
現(xiàn)在 gcd 允許計算任意數(shù)量的數(shù)字。
import math
# Greatest common divisor
math.gcd(80, 64, 152)
# 8
Math模塊中,另一個新增的功能是:
# 最小公倍數(shù)
math.lcm(4, 8, 5)
# 40
用于計算最小公倍數(shù):math.lcm,與gcd一樣,它允許可變數(shù)量的參數(shù)。
4.新的解析器—PEG
這一個更改你可能看不見、摸不著,但它可能改變Python的未來。
以前Python使用 LL(1) 解析器,從Python 3.9 開始,將使用 PEG 解析器,官方認為,這個更改會使得他們更加方便地構(gòu)建新功能。
-
生成器
+關(guān)注
關(guān)注
7文章
313瀏覽量
20951 -
詞典
+關(guān)注
關(guān)注
0文章
6瀏覽量
8115 -
python
+關(guān)注
關(guān)注
55文章
4768瀏覽量
84376 -
運算符
+關(guān)注
關(guān)注
0文章
171瀏覽量
11051
發(fā)布評論請先 登錄
相關(guān)推薦
評論