>  기사  >  웹 프론트엔드  >  일반 게으른 매칭 패턴 사용에 대한 자세한 설명(?)

일반 게으른 매칭 패턴 사용에 대한 자세한 설명(?)

php中世界最好的语言
php中世界最好的语言원래의
2018-03-30 11:34:391815검색

이번에는 일반 게으른 매칭 모드(?) 사용에 대한 자세한 설명을 가져왔습니다. 일반 게으른 매칭 모드(?) 사용 시 주의사항은 무엇인가요?

정규 표현게으른 매칭 모드:
욕심 매칭 모드에 관한 장에서 인간의 본성은 더 많은 돈, 지위, 심지어 아름다운 여성까지 얻기를 바라는 욕심이 많다고 했지만 금욕적인 사람들도 많이 있습니다. , 기본 요구 사항만 충족하면 일상적인 요구 사항을 충족할 수 있습니다. 정규 표현식에도 이러한 일치 원칙이 있습니다.

1. 게으른 모드의 개념:

이 모드는 정규식을 만족시키기 위해 가능한 한 적은 문자와 일치합니다. 예:

var str="axxyyzbdkb"; 
console.log(str.match(/a.*b/));

위 코드는 Greedy 모드입니다. string 전체를 지연 매칭 모드로 수정합니다:

var str="axxyyzbdkb"; 
console.log(str.match(/a.*?b/));

위 코드는 지연 매칭입니다. 방법은 반복 수량자 뒤에 물음표(?)를 추가하는 것입니다.
지연 일치 모드는 가능한 한 적은 수의 문자를 일치시키는 것이지만 정규식의 일치 규칙을 충족해야 합니다. 예를 들어 위 코드에서 *는 0개 이상의 이전 문자 또는 하위 표현식과 반복적으로 일치할 수 있지만 정규식은 end는 b여야 하므로 정규식은 위 문자열의 axxyyzb와 일치할 수 있습니다.

요약은 다음과 같습니다.

1. 반복 수량자 뒤에 물음표(?)를 추가하여 지연 일치를 만듭니다.
2. 지연 매칭은 가능한 적은 수의 문자와 일치하지만 전체 일치 패턴이 만족되어야 합니다.

2. Lazy qualifier 목록:

문법 구조 의미적 설명
*? 은 여러 번 반복할 수 있지만 가능한 한 적은 횟수로 반복할 수 있습니다.
+? 한 번 또는 원하는 만큼 반복할 수 있지만 가능한 한 적은 횟수로 반복하되 최소 횟수는 1회입니다.
?? 0번이나 1번 반복해도 되지만, 최대한 적게 반복하세요.
{n,m}? 이것을 n부터 m까지 반복할 수 있지만 가능한 한 적게 반복해야 합니다.
{n,}? 은 n회 이상 반복될 수 있지만, 가능한 한 적게 반복되어야 하며 최소한 n번은 일치해야 합니다.

首先引入一个介绍比较详细的网站

http://www.jb51.net/article/31491.htm

接下来是本人的简介

其实贪婪和惰性很容易理解,从字面意思我们就可以知道,所谓的"贪婪"的意思就是,如果符合要求就一直往后匹配,一直到无法匹配为止,这就是贪婪模式。所谓的惰性模式就是一旦匹配到合适的就结束,不在继续匹配下去了,下面我介绍几个例子来主要讲述一下。

首先讲述一下贪婪模式的标示符:+,?,*,{n},{n,},{n,m}.惰性模式:+?,??,*??,{n}?,{n,}?,{n,m}?;

例子一

var pattern=/8[a-zA-Z0-9]*7/;贪婪模式
var string="abc8defghij7klngon8qrstwxy7";

这时使用了贪婪模式*,表示8与8之间可有有任意多个字母,那这个正则先匹配第一个8,如果匹配到了后,就无限制的匹配后面的内容,只要后面的内容都满足[a-zA-Z0-9]就可以。一直匹配,匹配到不能再匹配为止,看紧接着后面的一个是不是7,如果不是那他就往前进一个(吐出一个看是不是7),如果不是再继续吐直到吐出7为止,然后匹配到的就是这之间的内容。所以结果匹配到的内容就是整条字符串。

var pattern=/8[a-zA-Z0-9]*?7/ig;惰性模式
var string="abc8defghij7klngon8qrstwxy7";

上面正则使用了惰性模式*?,此时匹配方式是这样的,先匹配一个8,然后在往后匹配一个字符看是不是符合[a-zA-Z0-9],如果符合,再去看紧接着后面的一个字符是不是7,如果是7就结束,如果不是就再往后匹配一个字符,看是不是符合[a-zA-Z0-9],如果符合,就再看紧接着后面的一个字符是不是7,如果是7就结束,否则,按照上面的方式依次循环下去,指导符合为止。

(2).贪婪和惰性模式还可以用另一种方式来表达。

例子二

var test="<img src="aaa/111.jpg"/><img src="aaa/112.jpg"/><img src="aaa/113.jpg"/>";
var pattern=/<img [^>]*\/>/ig;

这样也可以实现惰性模式,[^>]这个表示的就是在之间不能出现>,所以结果可以找寻每个标签。

相信看了本文案例你已经掌握了方法,更多精彩请关注php中文网其它相关文章!

推荐阅读:

js里的正则实现数字每隔四位用空格分隔效果

在PHP里使用正则的效率 贪婪、非贪婪与回溯详解(附代码)

위 내용은 일반 게으른 매칭 패턴 사용에 대한 자세한 설명(?)의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.