正则表达式(捕获组和非捕获组)

数量词 X? X,一次或一次也没有 X* X,零次或屡次 X+ X,一次或屡次 X{n} X,刚好 n 次 X{n,} X,至少 n 次 X{n,m} X,至少 n 次,可是不超过 m 次 若是要对一段字符进行重复,就须要有用到分组,分组在正则中用"()"表示.而后后面能够对这个组进行重复 引用.例如(123) 123就是一个组. 分组有两种概念,非捕获组和捕获组 捕获组 ( ) 每个捕获组都会有编号,这个编号是从左至右经过括号来计算的.例如 (A(B)(CD)) 第1组:(A(B)(CD)) 第2组:(B) 第3组:(CD)正则表达式

在正则表达式中能够对捕获组进行引用。内存

下面写一个对捕获组进行引用的例子 选取靓号 数字所有相同的号码(AAAAAA) (\d)\1{6,} 首先会获取第一位为0-9的数字,而后\1引用第一组里面内容而后重复6次或者6次以上.资源

说明 每一对括号会分配一个编号,使用 () 的捕获根据左括号的顺序从 1 开始自动编号。捕获元素编号为零的第一个捕获是由整个正则表达式模式匹配的文本。 非捕获组(?:xxx)搜索

以 (?) 开头的组是纯的非捕获 组,它不捕获文本 ,也不针对组合计进行计数。就是说,若是小括号中以?号开头,那么这个分组就不会捕获文本,固然也不会有组的编号,所以后面也不能引用。引用

表达式 方向 说明 (?=xxx) 正向预搜索(向右) 正向预搜索,判断当前位置右侧是否能匹配指定表达式 (?!xxx) 正向预搜索(向右) 正向预搜索否认,判断当前位置右侧是否不可以匹配指定表达式 (?<=xxx) 反向预搜索(向左) 反向预搜索,判断当前位置左侧是否可以匹配指定表达式 (?<!xxx) 反向预搜索(向左) 反向预搜索否认,判断当前位置左侧是否不可以匹配指定表达式字符

与普通分组不一样的是,非捕获组不记录所匹配的内容,比普通分组更节约内存资源。 例子:数字

  1. (?<=2)88(?<!3) 88前面是2后面不能是3 2884 匹配 3882 不匹配