Python 3.9 如何修復(fù)裝飾器并改進(jìn)字典
探索最近版本的 Python 的一些有用的特性。
這是 Python 3.x 首發(fā)特性系列文章中的第十篇,其中一些版本已經(jīng)發(fā)布了一段時(shí)間。Python 3.9 在 2020 年首次發(fā)布,具有很酷的新特性,但仍未被充分利用。下面是其中的三個(gè)。
添加字典
假設(shè)你有一個(gè) defaults
字典,而你想更新它的參數(shù)。在 Python 3.9 之前,最好的辦法是復(fù)制 defaults
字典,然后使用 .update()
方法。
Python 3.9 為字典引入了聯(lián)合運(yùn)算符:
defaults = dict(who="someone", where="somewhere")
params = dict(where="our town", when="today")
defaults | params
{'who': 'someone', 'where': 'our town', 'when': 'today'}
注意,順序很重要。在這種情況下,正如預(yù)期,來自 params
的 where
值覆蓋了默認(rèn)值。
刪除前綴
如果你用 Python 做臨時(shí)的文本解析或清理,你會(huì)寫出這樣的代碼:
def process_pricing_line(line):
if line.startswith("pricing:"):
return line[len("pricing:"):]
return line
process_pricing_line("pricing:20")
'20'
這樣的代碼很容易出錯(cuò)。例如,如果字符串被錯(cuò)誤地復(fù)制到下一行,價(jià)格就會(huì)變成 0
而不是 20
,而且會(huì)悄悄地發(fā)生。
從 Python 3.9 開始,字符串有了一個(gè) .lstrip()
方法:
"pricing:20".lstrip("pricing:")
'20'
任意的裝飾器表達(dá)式
以前,關(guān)于裝飾器中允許哪些表達(dá)式的規(guī)則沒有得到充分的說明,而且很難理解。例如:雖然
@item.thing
def foo():
pass
是有效的,而且:
@item.thing()
def foo():
pass
是有效的,相似地:
@item().thing
def foo():
pass
產(chǎn)生一個(gè)語法錯(cuò)誤。
從 Python 3.9 開始,任何表達(dá)式作為裝飾器都是有效的:
from unittest import mock
item = mock.MagicMock()
@item().thing
def foo():
pass
print(item.return_value.thing.call_args[0][0])
<function foo at 0x7f3733897040>
雖然在裝飾器中保持簡(jiǎn)單的表達(dá)式仍然是一個(gè)好主意,但現(xiàn)在是人類的決定,而不是 Python 分析器的選擇。
歡迎來到 2020 年
Python 3.9 大約在一年前發(fā)布,但在這個(gè)版本中首次出現(xiàn)的一些特性非???,而且沒有得到充分利用。如果你還沒使用,那么將它們添加到你的工具箱中。