pampy超强的模式匹配工具的实现
作者:Python测试开发 发布时间:2023-03-05 23:05:07
标签:pampy,模式匹配工具
目录
何为模式匹配
下载pampy
栗子
单个字符匹配
匹配开头和结尾
匹配字典的key
使用
特性1: HEAD 和 TAIL
特性2:甚至能匹配字典中的键
特性3: 搭配正则
何为模式匹配
模式匹配即给定某种模式,用这种模式去检查序列或字符串是否符合这种模式,这种技术在自然语言处理中经常使用。
下载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('我的天,你长得真像鳕鱼')) # => '你像鳕鱼'
来源:https://juejin.cn/post/6981735556690477063


猜你喜欢
- 对于一般的图像提取轮廓,介绍了一个很好的方法,但是对于有噪声的图像,并不能很好地捕获到目标物体。比如对于我的鼠标,提取的轮廓效果并不好,因为
- 注意转义字符\的使用\\,\",\$ 注意使用8进制或16进制字符表示 \xf6 echo "H\xf6me"
- 如何用ASP发送HTML格式的邮件?HTML格式的邮件可以把网页上的所有元素,包括文字和图片集成保存在一个文件中,阅读和链接非常便捷,请问在
- 用下面这个函数:Function CheckStringLength(txt) &n
- 我就废话不多说了,大家还是直接看代码吧~#! /usr/bin/env python# -*- coding:utf-8 -*-import
- Himmelblau函数如下:有四个全局最小解,且值都为0,这个函数常用来检验优化算法的表现如何:可视化函数图像:import numpy
- 下面的request.servervariables例子都是服务器探针采用的asp代码本机ip:<%=request.serverva
- 1. 引言最近闲暇之余,我会去阅读一些Python文档,有时候会注意到一些有趣的Python特性,这些特性不禁让人惊呼:&ldquo
- 实际中,很多数据都是存为txt文件、csv文件等,但是在程序中处理的时候numpy数组或列表是最方便的。本文简单介绍读入txt文件以及将之转
- 关于模型保存的一点心得saver = tf.train.Saver(max_to_keep=3)在定义 saver 的时候一般会定义最多保存
- 前言:了解了一下MySQL数据库的基本语句,这章了解一下它的高级操作,包括用户增删除与给予相对应的权限一.克隆表1.1克隆方法一(将表与内容
- 我们可以通过 asyncio.wait() 函数等待异步任务完成。可以等待不同的条件,例如所有任务完成、第一个任务完成以及第一个任务因异常而
- 最近服务器升级到了win2008 r2,数据库也从sql2000升级到了sql2005,不过安装后发现sql server找不到服务器名这样
- 如果你用SQL Server 2005 Management Studio建立函数或存储过程,你会注意到这些新窗口中都是模板。通常,你可以获
- 因为使用python+selenium有时候需要获取当前文件的上一级目录,找了一段时间找到了,在此记录下来;os.path.dirname(
- 几何变换图像的几何变换是指将一幅图像映射到另一幅图像内。有缩放、翻转、仿射变换、透视、重映射等操作。1 缩放使用cv2.resize()函数
- 本文实例讲述了js获取checkbox值的方法。分享给大家供大家参考。具体实现方法如下:<html><head>&l
- 下午在用python将Linux的conf配置文件转化成字典dict时遇到了一个奇怪的问题,原先conf配置文件中没有注释行(以#开头的行)
- 1.问题描述当我们在实用ElementUI组件完成项目的时候可能会遇到这样的需求,比如:新建一个活动,需要定义活动的时间范围;因此我们在新建
- 0.前言添加colormap的对象是灰度图,可以变成热量图,从而更加明显的发现一些规律,适用于一些雷达图像等from PIL import