Python神器之Pampy模式匹配庫的用法詳解
大家好,我是閑歡,一個很卷的程序員!
今天給大家分享一個炒雞炒雞簡單又好用的神器——pampy。
我敢以我的榮譽保證,用了它之后,你寫代碼的效率可以蹭蹭蹭地提升!
Pampy 是哪路神仙
首先普及一下模式匹配。
模式匹配即給定某種模式,用這種模式去檢查序列或字符串是否符合這種模式,這種技術在自然語言處理中經(jīng)常使用。
Pampy 是 Python 的一個模式匹配類庫,一個只有150行的類庫,該庫優(yōu)雅、高效值得廣大Python的碼農加入自己基本開發(fā)棧中。
無獨有偶,該程序還有一個同名的 Pampy.js 的 JavaScript 版本庫。
你如果有興趣,可以閱讀源碼,將其照搬到更多的開發(fā)語言中。
安裝這個庫的方式也是老生常談了:
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
匹配了兩個字符,輸出的時候,如果是多個字符,結果會以數(shù)組的方式給出。
總結
Pampy 的例子都很簡單,大家一閱便知。通過看著幾個例子,是不是有種感覺:哇,還有這等神器!
當然,Pampy 的模式匹配不止這么幾種方式,下面為大家解釋一下
特性1: HEAD 和 TAIL
HEAD和TAIL能代表某個模式的前面部分或后面部分。
比如將特定模式后的元素都變成元組:
from pampy import match, HEAD, TAIL, _ x = [-1, -2, -3, 0, 1, 2, 3] print(match(x, [-1, TAIL], lambda t: [-1, tuple(t)])) # => [-1, (-2, -3, 0, 1, 2, 3)]
將特定模式前的元素設為集合,后面的元素設為元組:
from pampy import match, HEAD, TAIL, _ x = [-1, -2, -3, 0, 1, 2, 3] print(match(x, [HEAD, _, _, 0, TAIL], lambda h, a, b, t: (set([h, a, b]), tuple(t)))) # => ({-3, -1, -2}, (1, 2, 3))
特性2: 甚至能匹配字典中的鍵
在你不知道哪個鍵下有某個值的時候,這招非常好用:
from pampy import match, HEAD, TAIL, _ my_dict = { 'global_setting': [1, 3, 3], 'user_setting': { 'face': ['beautiful', 'ugly'], 'mind': ['smart', 'stupid'] } } result = match(my_dict, { _: {'face': _}}, lambda key, son_value: (key, son_value)) print(result) # => ('user_setting', ['beautiful', 'ugly'])
特性3: 搭配正則
不僅如此,它還能搭配正則一起使用哦:
import re from pampy import match, HEAD, TAIL, _ def what_is(pet): return match( pet, re.compile('(\w+),(\w)\w+鱈魚$'), lambda mygod, you: you + "像鱈魚" ) print(what_is('我的天,你長得真像鱈魚')) # => '你像鱈魚'
到此這篇關于Python神器之Pampy模式匹配庫的用法詳解的文章就介紹到這了,更多相關Python Pampy內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
Python?selenium?webdriver?基本使用代碼分享
這篇文章主要介紹了Python?selenium?webdriver?基本使用,本文僅僅簡單介紹了selenium的使用常用代碼分享,需要的朋友可以參考下2022-11-11django之對django內置的User模型進行自定義擴展方式
這篇文章主要介紹了django之對django內置的User模型進行自定義擴展方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-05-05Python?selenium實現(xiàn)大麥網(wǎng)自動購票過程解析
大麥網(wǎng)是中國綜合類現(xiàn)場娛樂票務營銷平臺,業(yè)務覆蓋演唱會、?話劇、音樂劇、體育賽事等領域,今天我們要用代碼來實現(xiàn)他的購票過程,感興趣的朋友一起看看吧2022-05-05Pycharm使用Conda激活環(huán)境失敗的問題解決
本文主要介紹了Pycharm使用Conda激活環(huán)境失敗的問題解決,文中主要介紹了兩種問題的解決,具有一定的參考價值,感興趣的可以了解一下2023-09-09