本測試使用python的re.compile與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 不在此位置的左側匹配時才繼續匹配。例如,(?

  從斷言的表達形式可以看出,它用的就是分組符號,只不過開頭都加了一個問號,這個問號就是在說這是一個非捕獲組,這個組沒有編號,不能用來后向引用,只能當做斷言。(對于正則表達式的斷言感興趣的同學,可以再查一查資料,這里不多做贅述)

  所以這里我們不想匹配abc字符串就得用這個表達式: (?!abc)

  測試代碼:

  import re

  p = re.compile(r'error(?!abc)'

  print p.search("errorabc")

  print p.search("errorab")

  結果:

  None

  <_sre.SRE_Match object at 0x7f129ce34b90>

  那么我想不匹配"error123bsc"這個字符串呢?你是不是以為 error.*(?!abc) 這么寫這個正則就可以了,我們來試試

  import re

  p = re.compile(r'error.*(?!abc)'

  print p.search("error123abc")

  結果:

  <_sre.SRE_Match object at 0x7f129ce34bf8>

  看,失敗了吧!那怎么寫呢?這么寫:error((?!abc).)*$

  知道了(?!abc),那么可以理解((?!abc).)* 的意思就是匹配 不含abc的字符(?!abc) 跟 任意字符. 的組合,出現任何次*

  很多人會問,"$"不是匹配行末尾么,確實是這個意思,不明白請精度上面一句話再來看正則,然后我們來測一下:

  import re 無錫人流醫院 http://www.0510bhyy.com/

  p = re.compile(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 = re.compile(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 = re.compile(r'error((?!(abc|def)).)*$')

  print p.search("error123abc234")

  print p.search("error123ab234")

  print p.search("error123def234")

  結果:

  None

  <_sre.SRE_Match object at 0x7f87973eccf0>

  None

  測試完成!