正则表达式(.*?)惰性匹配()

Posted 风泊月

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了正则表达式(.*?)惰性匹配()相关的知识,希望对你有一定的参考价值。

1、. 匹配任意除换行符“\\n”外的字符;
2、表示匹配前一个字符0次或无限次;
3、?表示前边字符的0次或1次重复
4、+或
后跟?表示非贪婪匹配,即尽可能少的匹配,如*?重复任意次,但尽可能少重复;
5、 .? 表示匹配任意数量的重复,但是在能使整个匹配成功的前提下使用最少的重复。
如:a.
?b匹配最短的,以a开始,以b结束的字符串。如果把它应用于aabab的话,它会匹配aab和ab。

(?:pattern)
非获取匹配,匹配pattern但不获取匹配结果,不进行存储供以后使用。这在使用或字符“(|)”来组合一个模式的各个部分是很有用。例如“industr(?:y|ies)”就是一个比“industry|industries”更简略的表达式。
(?=pattern)
非获取匹配,正向肯定预查,在任何匹配pattern的字符串开始处匹配查找字符串,该匹配不需要获取供以后使用。例如,“Windows(?=95|98|NT|2000)”能匹配“Windows2000”中的“Windows”,但不能匹配“Windows3.1”中的“Windows”。预查不消耗字符,也就是说,在一个匹配发生后,在最后一次匹配之后立即开始下一次匹配的搜索,而不是从包含预查的字符之后开始。
(?!pattern)
非获取匹配,正向否定预查,在任何不匹配pattern的字符串开始处匹配查找字符串,该匹配不需要获取供以后使用。例如“Windows(?!95|98|NT|2000)”能匹配“Windows3.1”中的“Windows”,但不能匹配“Windows2000”中的“Windows”。
(?<=pattern)
非获取匹配,反向肯定预查,与正向肯定预查类似,只是方向相反。例如,“(?<=95|98|NT|2000)Windows”能匹配“2000Windows”中的“Windows”,但不能匹配“3.1Windows”中的“Windows”。

    var a = /^(?=.*[a-z])(?=(?:.*?[A-Z])2)(?=.*\\d)[a-zA-Z\\d]6$/;

一共6位至少一个小写字母一个数字两个大写字母

以上是关于正则表达式(.*?)惰性匹配()的主要内容,如果未能解决你的问题,请参考以下文章

正则表达式(.*?)惰性匹配()

正则表达式(.*?)惰性匹配()

搜索 2 个特定字母后跟 4 个数字 Regex

用于匹配 JSON 子字符串某些部分的 Java 正则表达式

正则表达式(.*?)(.+?)惰性匹配

正则表达式匹配所有字符实例,除非后跟数字或单独