可以用零宽断言来代替。例如(?=[A-Z])(?!AZ).{2}(?=[A-Z]{2})表示断言后面的内容是两位大写字母(?!AZ)表示断言后面的内容不能是AZ.{2}匹配两位字符三者结合起来,相当于:两位大写字母“且”不能是AZ“且”有两位字符。零宽断言有四类,它不匹配字符,只匹配一个位置,这和\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}匹配前面不是小写字母的七位数字。