python正则表达式解决包含且不包含某字符串的问题python正则表达式不包含
python 正则表达式解决包含且不包含某字符串的问题
本测试使⽤python的repile与re.search作为⽅法测试包含error不包含abc的实例
python简单正则⾥只介绍到了不包含某字符的正则:[^1-9a-z],[^abc]也只能完成不匹配a、b、c三个字母的功能,但是这个并不能实现不匹配"abc“字符串的功能
这⾥要⽤到正则表达式中的断⾔知识:
(?=X )零宽度正先⾏断⾔。仅当⼦表达式 X 在 此位置的右侧匹配时才继续匹配。例如,/w+(?=/d) 与后跟数字的单词匹配,⽽不与该数字匹配。此构造不会回溯。
(?!X)零宽度负先⾏断⾔。仅当⼦表达式 X 不在 此位置的右侧匹配时才继续匹配。例如,例如,/w+(?!/d) 与后不跟数字的单词匹配,⽽不与该数字匹配 。
(?
<=X)零宽度正后发断⾔。仅当⼦表达式 X 在 此位置的左侧匹配时才继续匹配。例如,(?<=19)99 与跟在 19 后⾯的 99 的实例匹配。此构造不会回溯。
(? <!X)零宽度负后发断⾔。仅当⼦表达式 X 不在此位置的左侧匹配时才继续匹配。例如,(?<!19)99 与不跟在 19 后⾯的 99 的实例匹配
从断⾔的表达形式可以看出,它⽤的就是分组符号,只不过开头都加了⼀个问号,这个问号就是在说这是⼀个⾮捕获组,这个组没有编号,不能⽤来后向引⽤,只能当做断⾔。(对于正则表达式的断⾔感兴趣的同学,可以再查⼀查资料,这⾥不多做赘述)
所以这⾥我们不想匹配abc字符串就得⽤这个表达式: (?!abc)
测试代码:
import re
p = repile(r'error(?!abc)'
print p.search("errorabc")
print p.search("errorab")
结果:
None
<_sre.SRE_Match object at 0x7f129ce34b90>
那么我想不匹配"error123bsc"这个字符串呢?你是不是以为 error.*(?!abc) 这么写这个正则就可以了,我们来试试
import re
p = repile(r'error.*(?!abc)'
print p.search("error123abc")
结果:
<_sre.SRE_Match object at 0x7f129ce34bf8>
看,失败了吧!那怎么写呢?这么写:error((?!abc).)*$
知道了(?!abc),那么可以理解((?!abc).)*  的意思就是匹配  不含abc的字符(?!abc) 跟 任意字符. 的组合,出现任何次* 很多⼈会问,"$"不是匹配⾏末尾么,确实是这个意思,不明⽩请精度上⾯⼀句话再
来看正则,然后我们来测⼀下:
import re
p = repile(r'error((?!abc).)*$')
print p.search("error123abc")
print p.search("error123abc123")
print p.search("error123ab123")
结果:
None
None
<_sre.SRE_Match object at 0x7f129ce81a08>
明⽩了吧!
以此类推,你要是想匹配包含error不包含error前后的abc,那么应该是这么写这个正则:
测⼀下:
import re
p = repile(r'^((?!abc).)*error((?!abc).)*$')
print p.search("123abc123error123")
print p.search("123ab123error123")
结果:
None
<_sre.SRE_Match object at 0x7f129ce81a08>
我们要是想匹配包含error不包含多个字符串,⽐如abc和def,这么写正则: error((?!(abc|def)).)*$
测试:
import re
p = repile(r'error((?!(abc|def)).)*$')
print p.search("error123abc234")
print p.search("error123ab234")
print p.search("error123def234")
结果:
None
<_sre.SRE_Match object at 0x7f87973eccf0>
None
测试完成!

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。