可以用零宽断言来实现。
例如:
合并下列正则表达式:
A. 必须包含数字的正则表达式 .*\d
B. 必须包含英文的正则表达式 .*[a-zA-Z]
C.
字符串
长度是8-12位的正则表达式 ^.{8,12}$
合并后结果:
(?=.*\d)(?=.*[a-zA-Z])^.{8,12}$
表示必须包含数字,必须包含字母,同时长度为8-12位的正则表达式
零宽断言语法:
零宽断言有四类,它不匹配字符,只匹配一个位置,这和\b很像。用于断言后面的内容。
(?=exp)也叫零宽度正预测先行断言,它断言自身出现的位置的后面能匹配表达式exp。比如\b\w+(?=ing\b),匹配以ing结尾的单词的前面部分(除了ing以外的部分),如查找I'm singing while you're dancing.时,它会匹配sing和danc。
(?<=exp)也叫零宽度正回顾后发断言,它断言自身出现的位置的前面能匹配表达式exp。比如(?<=\bre)\w+\b会匹配以re开头的单词的后半部分(除了re以外的部分),例如在查找reading a book时,它匹配ading。
零宽度负预测先行断言(?!exp),断言此位置的后面不能匹配表达式exp。例如:\d{3}(?!\d)匹配三位数字,而且这三位数字的后面不能是数字;\b((?!abc)\w)+\b匹配不包含连续字符串abc的单词。
同理,我们可以用(?<!exp),零宽度负回顾后发断言来断言此位置的前面不能匹配表达式exp:(?<![a-z])\d{7}匹配前面不是小写字母的七位数字。