正则表达式前瞻(?=)、后顾(?<)、负前缀(?!)、负后顾(?<!)

正则表达式前瞻(?=)、后顾(?<)、负前缀(?!)、负后顾(?<!)

正则表达式前瞻、后顾这几个概念好像比较少会碰到,但是对于解决一些特定的匹配问题有非常重要的作用。

这几个概念的英文是 Lookahead and Lookbehind Zero-Length Assertions ,完整的中文名应该是前瞻后顾零宽断言。它匹配一些字符,但是并不包含匹配模式,只是确定是否匹配,也就是所谓的零宽。

前瞻 Lookahead 使用 ?=q(?=u) ,表示 u 前面是 q ,也就是 q 后面跟 u , 但匹配结果中不包含 u (零宽)。

同理,后顾 Lookbehind 使用 ?<(?<q)u 表示 q 后面是 u,也就是 u 前面为 q , 但匹配结果不包含 q (零宽)。

而这两个方式的相反匹配,负前瞻 q(?!u) 和负后顾 (?<!q)u ,分别表示 不为 u 的前面是 q不为 q 的后面是 u

下面是一下例子:

abc(?=123)      abc123      匹配,abc
                123abc      不匹配
abc(?!123)      abc123      不匹配
                abc456      匹配,abc
                def123      不匹配
(?<abc)123      abc123      匹配,123
                def123      不匹配
(?<!abc)123     abc123      不匹配
                def123      匹配,123
                kkk123      匹配,123

在涉及到正则表达式非的概念时,通常使用到前瞻后顾很好解决。

原文地址:https://www.cnblogs.com/fengyc/p/11546341.html

时间: 2024-10-09 12:49:01

正则表达式前瞻(?=)、后顾(?<)、负前缀(?!)、负后顾(?<!)的相关文章

由多个电容组成的去耦旁路电路,电容怎么布局摆放,先大后小还是先小后大?

由多个电容组成的去耦旁路电路,电容怎么布局摆放,先大后小还是先小后大? PCB设计规范与指南, 电磁兼容 EMC, 高频高速PCB设计 by xfire 去耦旁路电磁兼容高速电路设计 对于噪声敏感的IC电路,为了达到更好的滤波效果,通常会选择使用多个不同容值的电容并联方式,以实现更宽的滤波频率,如在IC电源输入端用1μF.100nF和10nF并联可以实现更好的滤波效果.那现在问题来了,这几个不同规格的电容在PCB布局时该怎么摆,电源路径是先经大电容然后到小电容再进入IC,还是先经过小电容再经过大

关于DEDECMS自定义模型当中添加自定义字段后在后台添加内容后不显示解决方案

用DEDECMS的时间也不长,最近在做一个站时,就遇到了这个问题(自定义字段在后台不显示内容)中添加自定义字段后在后台编辑打开后发现我之前添加的内容不显示,如果是只是看看不单击确定的话,那么在前台数据的调用就是正常的,但是再次回到后台发现,那个几个字段就是不显示,没办法,在网上查了一下,还是没有找到问题的原因,算了于是自己看了一下他的附加表当中是不是有什么问题,打开后发现了,原来是在数据库里面字段的名是大写(PS:我在添加自定义字段是喜欢首字母大写)应该不会是这个问题吧!于是我把他们改成了小写字

Eclipse复制或修改项目后,把项目部署后发现还是原来的项目名称

解决: 到项目根目录打开.setting文件夹,找到"org.eclipse.wst.common.component" 修改这三处名字要求和部署的项目名称一致就可以了! 最后要重启eclipse!!! Eclipse复制或修改项目后,把项目部署后发现还是原来的项目名称

装完RHEL7后,重新开机启动后显示:Initial setup of CentOS Linux 7 (core) 提示license报错

装完RHEL7后,重新开机启动后显示: 1) [x] Creat user 2) [!] License information (no user will be created) (license not accepted) Please make your choice from above ['q' to quit | 'c' to continue | 'r' to refresh]: 解决方法: 输入"1",按Enter键 输入"2",按Enter键 输入

表结构更改后或新增加数据后同步到表中

select 'insert into mtx_system_module(module_id,module_code,module_name,module_note,create_date,version)values('+cast(moduleid as varchar(10))+','''+ObjectID+''','''+Name+''','''+isnull(Note,'')+''',NOW(),1);' from AppModules where subsystem=1 and Pa

实现每次触发事件后隔一段时间后才能再次触发事件

比如: 每次点击“提交”按钮后隔3s后才能再次提交. 可以这样:点击后设置按钮不可用,并在3s后再设置按钮可用 $('#button1').click(function(){ //在这里提交或做别的事 $(this).attr("disabled",true); setTimeout("$('#button1').attr('disabled',false);", 3000); //此处setTimeout里面不能用$(this),this指的是window对象 }

python正则表达式(8)--分组、后向引用、前(后)向断言

无名.有名分组 (1)正则表达式-无名分组 从正则表 达式的左边开始看,看到的第一个左括号"("表示表示第一个分组,第二个表示第二个分组, 依次类推. 需要注意的是,有一个隐含的全局分组(就是索引号为0的分组),就是整个正则 表达式匹配的结果 (2)正则表达式-有名分组 命名分组就是给具体有默认分组编号的组另外再起一个别名,方便以后的引用. 命令分组的语法格式如下: (?P<name>正则表达式) 语法格式中的字符P必须是大写的"P",name是一个合法

正则表达式之正向预查和负向预查

日常工作当中,大多数IDE自带的查找工作都能满足大多数需要. 加上正则匹配简直如虎添翼.匹配个邮箱,电话号什么的不在话下.有时候我们可能会遇到稍微特殊的场景. Windows 1.03 and Windows 2.0 fisrt Released in 1985 and 1987 respectively.Windows 95 and Windows 98 are the successor.Then Windows 2000 and Windows Xp Windows appeared.Wi

由二叉树的前序遍历和后序遍历来求后序遍历的结果

假设有棵树,长下面这个样子,它的前序遍历,中序遍历,后续遍历都很容易知道. PreOrder:         GDAFEMHZ InOrder:            ADEFGHMZ PostOrder:       AEFDHZMG 现在,假设仅仅知道前序和中序遍历,如何求后序遍历呢?比如,已知一棵树的前序遍历是"GDAFEMHZ",而中序遍历是"ADEFGHMZ"应该如何求后续遍历? 第一步,root最简单,前序遍历的第一节点G就是root. 第二步,继续观