溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

pampy超強(qiáng)的模式匹配工具怎么用

發(fā)布時(shí)間:2021-07-07 18:27:04 來源:億速云 閱讀:154 作者:小新 欄目:開發(fā)技術(shù)

小編給大家分享一下pampy超強(qiáng)的模式匹配工具怎么用,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

何為模式匹配

模式匹配即給定某種模式,用這種模式去檢查序列或字符串是否符合這種模式,這種技術(shù)在自然語言處理中經(jīng)常使用。

下載pampy

pip install pampy

栗子

單個(gè)字符匹配

以下代碼可以完成單個(gè)字符在對(duì)象中的匹配,使用_表示匹配結(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é)尾

對(duì)于開頭或者結(jié)尾連續(xù)的對(duì)象,我們可以使用這種方式實(shí)現(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匹配了開頭的若干字符,中間使用_匹配了某個(gè)數(shù)字,結(jié)尾我們使用TAIL配了若干字符。

匹配字典的key

當(dāng)我們只知道某個(gè)字典的部分內(nèi)容,卻想要得到某個(gè)value的key時(shí),用這種方式事半功倍。

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))

運(yùn)行結(jié)果:

>>> python test.py
>>> {'key1': 'phone', 'key2': 'huawei'}

如上,我們已經(jīng)匹配到了字典的第一層和第二層的Key值。

如上面的例子,我們的模式一定要保持字典結(jié)構(gòu)的完整。

使用

特性1: HEAD 和 TAIL

HEAD和TAIL能代表某個(gè)模式的前面部分或后面部分。

比如將特定模式后的元素都變成元組:

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:甚至能匹配字典中的鍵

在你不知道哪個(gè)鍵下有某個(gè)值的時(shí)候,這招非常好用:

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('我的天,你長得真像鱈魚'))     # => '你像鱈魚'

以上是“pampy超強(qiáng)的模式匹配工具怎么用”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請(qǐng)聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI