作為一名不經(jīng)常使用正則表達式的程序員,想用最簡單的語言來描述否定匹配蜓氨,不過發(fā)現(xiàn)確實不是那么好理解聋袋。還是按照自己知道的來描述吧。
正則規(guī)則描述
[ ] :表示范圍穴吹,匹配其中任何一個
{ }:表示重復(fù)匹配多次幽勒。
( ): 表示分組,意思就是括號內(nèi)是一個整體港令。
關(guān)于匹配
(?:pattern)
非獲取匹配啥容,匹配pattern但不獲取匹配結(jié)果,不進行存儲供以后使用缠借。這在使用或字符“(|)”來組合一個模式的各個部分是很有用干毅。例>>如“industr(?:y|ies)”就是一個比“industry|industries”更簡略的表達式宜猜。
(?=pattern)
非獲取匹配泼返,正向肯定預(yù)查,在任何匹配pattern的字符串開始處匹配查找字符串姨拥,該匹配不需要獲取供以后使用绅喉。例如,“Windows(?=95|98|NT|2000)”能匹配“Windows2000”中的“Windows”叫乌,但不能匹配“Windows3.1”中的“Windows”柴罐。預(yù)查不消耗字符,也就是說憨奸,在一個匹配發(fā)生后革屠,在最后一次匹配之后立即開始下一次匹配的搜索,而不是從包含預(yù)查的字符之后開始排宰。
(?!pattern)
非獲取匹配似芝,正向否定預(yù)查,在任何不匹配pattern的字符串開始處匹配查找字符串板甘,該匹配不需要獲取供以后使用党瓮。例如“Windows(?!95|98|NT|2000)”能匹配“Windows3.1”中的“Windows”,但不能匹配“Windows2000”中的“Windows”盐类。
(?<=pattern)
非獲取匹配寞奸,反向肯定預(yù)查呛谜,與正向肯定預(yù)查類似,只是方向相反枪萄。例如隐岛,“(?<=95|98|NT|2000)Windows”能匹配“2000Windows”中的“Windows”,但不能匹配“3.1Windows”中的“Windows”瓷翻。
(?<!pattern)
非獲取匹配礼仗,反向否定預(yù)查,與正向否定預(yù)查類似逻悠,只是方向相反元践。例如“(?<!95|98|NT|2000)Windows”能匹配“3.1Windows”中的“Windows”,但不能匹配“2000Windows”中的“Windows”童谒。這個地方不正確单旁,有問題
這些都是來源于網(wǎng)上,前人已經(jīng)總結(jié)的很好了饥伊。前人栽樹象浑,后人乘涼。我就乘乘涼好了琅豆。O(∩_∩)O哈哈~
本次使用 (?!pattern) 匹配愉豺,顯而易見它是匹配下一個字符串來判斷本次的匹配是否成功。當然這是一個否定匹配茫因。
問題
在文檔中匹配出蚪拦,不包含“hello”的字符串。
mm,bn,hello,ssdenl.
sdfsdf,dfdf,dfdfe,ggg.
sdfd,gfgf
dfdfgfgdfgsdfgsdfg
dfgfdg,sdfsdfdhello.sdfasdfas/
sdfsdfdfgdfgdsfhellosdfasdfasdf
sdfasdfdfgffghjdkfjglfdg
其中第1,5,6行包含有“hello”字符串冻押。當然這不是重點驰贷,重點是怎么來寫這個正則表達式。
當然洛巢,結(jié)論是:
^(?!.*hello).*$
運行效果:
將包含有“hello”的字符串全部排除掉了括袒。這樣就實現(xiàn)了我們想要的效果。
_
簡明解釋一下稿茉,這個語句的意思:
從頭開始匹配锹锰,否定匹配任意字符到“hello”,然后匹配任意字符到尾部結(jié)束。
大功告成漓库,回家睡覺恃慧。O(∩_∩)O哈哈~