這個Python神器,能讓你摸半天魚!
我敢以我的榮譽保證,用了它之后,你寫代碼的效率可以蹭蹭蹭地提升!
Pampy 是哪路神仙
首先普及一下模式匹配。
模式匹配即給定某種模式,用這種模式去檢查序列或字符串是否符合這種模式,這種技術在自然語言處理中經常使用。
Pampy 是 Python 的一個模式匹配類庫,一個只有150行的類庫,該庫優雅、高效值得廣大Python的碼農加入自己基本開發棧中。
無獨有偶,該程序還有一個同名的 Pampy.js 的 JavaScript 版本庫。
你如果有興趣,可以閱讀源碼,將其照搬到更多的開發語言中。
安裝這個庫的方式也是老生常談了:
- pip install pampy
Pampy 的花式秀
匹配單個字符
我們可以用 _ 來匹配單個字符:
from pampy import _,match
a=['a',1,'b',2,'c',3,'d',4]
patter = ['a',1,'b',_,'c',3,'d',4]
action=lambda x: f'b is: {x}'
print(match(a,patter,action))
運行結果是:
- b is: 2
從上面例子可以看出,實際上我們只是用 _ 充當一個占位符,當匹配的時候,找到這個占位符對應的元素即可。
匹配字典
我們可以匹配多層級的字典中的任意一個層級的 key 或者 value:
from pampy import _, match
person = {
'address': {'province': '湖北', 'city': '武漢', 'district': '東湖高新'},
'name': '閑歡'
}
patter = {_: {_: '武漢'}}
action = lambda k1, k2: ({'k1': k1, 'k2': k2})
print(match(person, patter, action))
運行結果是:
- {'k1': 'address', 'k2': 'city'}
跟前一個例子類似,這里使用 _ 這個占位符占位,然后在 action 里面定位占位符,即可輸出結果。
匹配開頭和結尾
上面的例子,我們都是使用占位符來占位,但是占位符只能匹配一個字符,下面的例子,我們將用 HEAD 和 TAIL 這兩個關鍵詞來匹配開頭和結尾,他們可以批評任意多個字符:
from pampy import _,match,HEAD,TAIL
a=['a',1,'b',2,'c',3,'d',4]
patter = [HEAD,_,'b',2,'c',3,TAIL]
action=lambda h,m,t: ({'head':h,'middle':m,'tail':t})
print(match(a,patter,action))
運行上面例子,結果是:
- {'head': 'a', 'middle': 1, 'tail': ['d', 4]}
我們可以從結果看到,HEAD 匹配了一個字符,TAIL 匹配了兩個字符,輸出的時候,如果是多個字符,結果會以數組的方式給出。
總結
Pampy 的例子都很簡單,大家一閱便知。通過看著幾個例子,是不是有種感覺:哇,還有這等神器!
當然,Pampy 的模式匹配不止這么幾種方式,還有更多方式有待大家去探索。