解释
预查又称环视(Lookaround)、属于零宽断言(Zero-Length Assertions)的一种,有 4 个语法:
语法 | 中文名 | 英文名 |
---|---|---|
(?=regex) |
肯定性前瞻 | Positive lookahead |
(?!regex) |
否定性前瞻 | Negative lookahead |
(? |
肯定性后顾 | Positive lookbehind |
(? |
否定性后顾 | Negative lookbehind |
比较通俗的解释:
-
肯定性:匹配
regex
-
否定性:不匹配
regex
- 前瞻:向前(右、正向)看(预查)
- 后顾:向后(左、反向)看(预查)
-
肯定性前瞻:先看看前方(右边)是否匹配
regex
,但不向前走 -
否定性前瞻:先看看前方(右边)是否不匹配
regex
,但不向前走 -
肯定性后顾:回头看后方(左边)是否匹配
regex
-
否定性后顾:回头看后方(左边)是否不匹配
regex
为什么右边是正向、前向,左边是反向、后向?
因为正则是从左往右匹配的,就像一个人在走,那么向前看(前瞻)就是右边、正向,向后看(后顾)就是左边、反向,特别注意不要和前缀后缀搞混
应用
1、判断是否同时包含但不限于大写字母、小写字母和数字,且不能包含 114514
,长度为 8~32 个字符
1 2 | /^(?=.*[A-Z])(?=.*[a-z])(?=.*d)(?!.*114514).{8,32}$/.test( '10086@qq.COM' ) // true |
2、判断不以 80
、82
、84
、86
、88
开头
1 2 | /^(?!8[02468])d+$/.test( '81789110' ) // true |
3、匹配由空白分割的字符串中的纯数字串
1 | '123 abc 1strn4 1970' s 56 @10086 789'.match(/(? |
4、仅删除夹在数字中的逗号
1 | 'And then, I have 1,003,334, you have 996,6,6,6' .replace(/(? |
5、在数字中添加分组逗号
1 | 'And then, I have 1003334, you have 996666' .replace(/(? |
6、判断是否仅包含字母,但不包含小写元音字母
1 2 3 4 | /^(?:(?![aeiou])[A-Za-z])+$/g.test( 'src' ) // true /^(?=[A-Za-z]+$)[^aeiou]+$/g.test( 'src' ) // true |
7、判断是否是字母或数字或字母+数字,不能为空
1 2 | /^(?=.)[a-z]*d*$/i.test( 'Add1' ) // true |
8、匹配长度为 11 的号码,注意不能是其他号码的子串
1 2 3 4 5 6 | `name:123456789 id:11012345678910 tel:12345678910 name:abc11111111111 id:888888888888 tel:11966`.match(/(? |
9、如果缺少协议前缀,则添加 http://
,忽略空行
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 | String.raw`segmentfault.com //bing.com baidu.com 127.0.0.1 ftp: //127.0.0.1 https: //google.com /* ftp://127.0.0.1 */ |
难点-为什么.?[^#/n]?.*?不行
- .?[^#/n]?.*?
- .?[^#/n]?相当于无,最后的.*?又匹配上了#号
- (?
总结
到此这篇关于正则表达式预查的详细解释与应用的文章就介绍到这了,更多相关正则表达式预查内容请搜索IT俱乐部以前的文章或继续浏览下面的相关文章希望大家以后多多支持IT俱乐部!