pampy超強的模式匹配工具的實現(xiàn)
何為模式匹配
模式匹配即給定某種模式,用這種模式去檢查序列或字符串是否符合這種模式,這種技術(shù)在自然語言處理中經(jīng)常使用。
下載pampy
pip install pampy
栗子
單個字符匹配
以下代碼可以完成單個字符在對象中的匹配,使用_表示匹配結(jié)果。
from pampy import _,match a=['a',1,'b',2,'c',3,'d',4] patter = ['a',1,'b',2,'c',3,'d',_] action=lambda x: f'result is: {x}' print(match(a,patter,action))
執(zhí)行結(jié)果:
>>> python test.py
>>> result is: 4
匹配開頭和結(jié)尾
對于開頭或者結(jié)尾連續(xù)的對象,我們可以使用這種方式實現(xiàn)快速匹配。
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,b,t: ({'head':h,'body':b,'tail':t}) print(match(a,patter,action))
執(zhí)行結(jié)果:
>>> python test.py
>>> {'head': 'a', 'body': 1, 'tail': ['d', 4]}
以上,我們使用HEAD匹配了開頭的若干字符,中間使用_匹配了某個數(shù)字,結(jié)尾我們使用TAIL配了若干字符。
匹配字典的key
當我們只知道某個字典的部分內(nèi)容,卻想要得到某個value的key時,用這種方式事半功倍。
from pampy import _,match,HEAD,TAIL my_dic={ 'phone':{'huawei':'ok','iphone':'good','chuizi':'bad'}, 'language':{ 'chinese':['xian','beijing'], 'english':['usa','canada'] } } patter = {_:{_:'ok'}} action=lambda a,b: {'key1':a,'key2':b} print(match(my_dic,patter,action))
運行結(jié)果:
>>> python test.py
>>> {'key1': 'phone', 'key2': 'huawei'}
如上,我們已經(jīng)匹配到了字典的第一層和第二層的Key值。
如上面的例子,我們的模式一定要保持字典結(jié)構(gòu)的完整。
使用
特性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)] 將特定模式前的元素設(shè)為集合,后面的元素設(shè)為元組: 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('我的天,你長得真像鱈魚')) # => '你像鱈魚'
到此這篇關(guān)于pampy超強的模式匹配工具的實現(xiàn)的文章就介紹到這了,更多相關(guān)pampy 模式匹配工具內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
使用Python實現(xiàn)企業(yè)微信通知功能案例分析
這篇文章主要介紹了使用Python實現(xiàn)企業(yè)微信通知功能,主要目的是通過企業(yè)微信應(yīng)用給企業(yè)成員發(fā)消息,通過案例分析給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-04-04Python 詳解通過Scrapy框架實現(xiàn)爬取CSDN全站熱榜標題熱詞流程
Scrapy是用純Python實現(xiàn)一個為了爬取網(wǎng)站數(shù)據(jù)、提取結(jié)構(gòu)性數(shù)據(jù)而編寫的應(yīng)用框架,用途非常廣泛,框架的力量,用戶只需要定制開發(fā)幾個模塊就可以輕松的實現(xiàn)一個爬蟲,用來抓取網(wǎng)頁內(nèi)容以及各種圖片,非常之方便2021-11-11Pytorch 使用opnecv讀入圖像由HWC轉(zhuǎn)為BCHW格式方式
這篇文章主要介紹了Pytorch 使用opnecv讀入圖像由HWC轉(zhuǎn)為BCHW格式方式,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-06-06一文解密Python中_getattr_和_getattribute_的用法與區(qū)別
這篇文章主要為大家詳細介紹了Python中_getattr_和_getattribute_的用法與區(qū)別,文中通過一些簡單的示例為大家進行了講解,需要的可以參考一下2023-01-01Pycharm 如何設(shè)置HTML文件自動補全代碼或標簽
這篇文章主要介紹了Pycharm 如何設(shè)置HTML文件自動補全代碼或標簽,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-05-05