婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > pampy超強的模式匹配工具的實現

pampy超強的模式匹配工具的實現

熱門標簽:企業彩鈴地圖標注 煙臺電話外呼營銷系統 預覽式外呼系統 上海正規的外呼系統最新報價 長春極信防封電銷卡批發 外賣地址有什么地圖標注 如何地圖標注公司 電銷機器人錄音要學習什么 銀川電話機器人電話

何為模式匹配

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

下載pampy

pip install pampy

栗子

單個字符匹配

以下代碼可以完成單個字符在對象中的匹配,使用_表示匹配結果。

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

執行結果:

>>> python test.py
>>> result is: 4

匹配開頭和結尾

對于開頭或者結尾連續的對象,我們可以使用這種方式實現快速匹配。

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

執行結果:

>>> python test.py
>>> {'head': 'a', 'body': 1, 'tail': ['d', 4]}

以上,我們使用HEAD匹配了開頭的若干字符,中間使用_匹配了某個數字,結尾我們使用TAIL配了若干字符。

匹配字典的key

當我們只知道某個字典的部分內容,卻想要得到某個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))

運行結果:

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

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

如上面的例子,我們的模式一定要保持字典結構的完整。

使用

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

到此這篇關于pampy超強的模式匹配工具的實現的文章就介紹到這了,更多相關pampy 模式匹配工具內容請搜索腳本之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • 詳解Python 最短匹配模式
  • 淺析Python 多行匹配模式
  • Python3標準庫glob文件名模式匹配的問題
  • python re模塊匹配貪婪和非貪婪模式詳解
  • python中正則表達式與模式匹配
  • Python3指定路徑尋找符合匹配模式文件

標簽:宜昌 湖北 西寧 盤錦 珠海 潮州 佳木斯 上饒

巨人網絡通訊聲明:本文標題《pampy超強的模式匹配工具的實現》,本文關鍵詞  pampy,超,強的,模式,匹配,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《pampy超強的模式匹配工具的實現》相關的同類信息!
  • 本頁收集關于pampy超強的模式匹配工具的實現的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 永仁县| 南宁市| 连城县| 礼泉县| 运城市| 信丰县| 图木舒克市| 繁昌县| 江永县| 万宁市| 临泽县| 定日县| 湖口县| 双辽市| 长宁区| 娄烦县| 曲阜市| 运城市| 专栏| 镇原县| 苏州市| 固安县| 岳阳县| 麻城市| 水城县| 平陆县| 炎陵县| 黎川县| 秦安县| 长白| 拉萨市| 天水市| 陵水| 兴安盟| 忻州市| 新密市| 如东县| 土默特左旗| 溆浦县| 天祝| 洛南县|