這篇文章主要介紹正則表達式后面不要包含指定字符串內(nèi)容的示例分析,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!
讓客戶滿意是我們工作的目標,不斷超越客戶的期望值來自于我們對這個行業(yè)的熱愛。我們立志把好的技術(shù)通過有效、簡單的方式提供給客戶,將通過不懈努力成為客戶在信息化領(lǐng)域值得信任、有價值的長期合作伙伴,公司提供的服務(wù)項目有:域名注冊、虛擬空間、營銷軟件、網(wǎng)站建設(shè)、鑲黃網(wǎng)站維護、網(wǎng)站推廣。
以前只會/<abc(?!def).+>/.exec("<abcdef>\n<abczzz>"),
匹配到<abczzz>,
這種簡單的固定寫法,但實際使用次數(shù)幾乎趨近于0。
很多場景不能寫死abc,順理成章的就寫成了/<.+(?!def).+>/.exec("<abcdef>\n<abczzz>"),
咦?咋把前面的匹配到了!從入門到放棄。
昨天(2019-04-07)隨手寫了一下/<(?:.(?!def))+>/.exec("<abcdef>\n<abczzz>"),
原來是對.+(?!排除的字符串)這個結(jié)構(gòu)能起到的作用理解錯了,怪不得達不到預期,(.(?!排除的字符串))+才是正解。
留下一個未解的問題,每個字符后面排除一下的能良好工作,一堆未定長度字符后排除一下怎么就不能工作,前瞻不會和前面的+、*、{}起作用嗎?解釋看結(jié)尾。
附:/<(?!.+def).+>/.exec("<abcdefzzz>\n<abczzz>")
寫法也可以??赡苁墙Y(jié)尾的.+導致的不能匹配,但這樣寫還是不行:/<.+(?!def)zzz>/.exec("<abcdefzzz>\n<abczzz>")。
正則表達式匹配指定內(nèi)容后面要或不要包含指定的字符串內(nèi)容:
?要:比較簡單,寫上這個要的即可
?不要:比要復雜很多,如何排除掉?
前提原則
1.表達式內(nèi)固定內(nèi)容的字符串能不寫盡量不寫,能簡寫的盡量簡化來寫(如前面寫的abc部分不能寫死)
2.可以少量使用前瞻(正向),后瞻(反向)基本不學,學了還要研究那些瀏覽器支持,不敢用,太多了也學不動。
3.NoJS(Not Only JavaScript);不僅僅是瀏覽器中的js;不過js的正則/exp/字面量寫法簡潔到?jīng)]盆友(哪個語言),函數(shù)、對象、字符串統(tǒng)統(tǒng)不需要;不接受反駁。
假設(shè)待匹配的文本
htmlRaw=` <div ***="*** ***" class="***" ***="***"> class=" matchX 1" <div ***="*** ***" class="*** matchX ***" ***="*** excludeX ***"> class=" matchX 2" </div> class=" matchX 3" </div> <div ***="*** ***" class="***" ***="***"> class=" matchX 4" <div ***="*** ***" class="*** ***" ***="***"> class=" matchX 5" </div> class=" matchX 6" </div> ...... `; //注: *** 不是固定內(nèi)容,但不會出現(xiàn)未轉(zhuǎn)義的xml實體、matchX、excludeX //注: class=" matchX 123456"純文本只做演示干擾之用,不應當作為特征 //如果數(shù)據(jù)對換行不敏感,應優(yōu)先轉(zhuǎn)換成沒有換行的,大概率可以簡化正則邏輯 htmlNoWrap=htmlRaw.replace(/[\r\n]+/g," "); //正則測試代碼 (/[\s\S]*/.exec(htmlRaw)||[])[0]
不要單個字符的匹配
匹配出div.matchX標簽:<div ***="*** ***" class="*** matchX ***" ***="***">
可以直接使用 [^>]把matchX限定在<> HTML標記內(nèi),意思就是<>中的文本不要出現(xiàn)結(jié)尾的>字符。
單個字符還算簡單:
//有效 /<div[^>]+matchX[^>]+>/.exec(htmlRaw)[0]
如果不限定在<>標記內(nèi),可能會匹配出界;并且這種不限定,遲早會出亂子:
//無效 /<div.+?matchX.+?>/.exec(htmlNoWrap)[0] /<div[\s\S]+?matchX[\s\S]+?>/.exec(htmlRaw)[0] //有換行符就是又長又難看
其他單個字符場景另行靈活運用。
不要一個字符串的匹配
匹配出第一層不帶excludeX文本內(nèi)容的第一塊div,就是返回包含matchX 4的那塊div
[^]語法只能排除掉單個字符,不要一個字符串咋辦?硬是要寫成[^abc],會把a、b、c字符全部排除掉;除了使用前瞻,好像還沒有別的簡單辦法。
使用本文開頭的(.(?!排除的字符串))+結(jié)構(gòu)就能達到目的,核心就在(?:[^>](?!excludeX))*:
//有效 /<div[^>]*>[^<]+<div(?:[^>](?!excludeX))*>[^<]+<\/div>[^<]+<\/div>/.exec(htmlRaw)[0]
要包含一個字符串的匹配,直接寫需要的字符串即可,相對簡單太多,就不寫這種例子了。
未研究(.(?!排除的字符串))+結(jié)構(gòu)的性能。
對于.+(?!排除)不能工作的釋疑
由于(?!排除)并不會作用于貪婪匹配到的每一個字符串,只會作用于.+貪婪匹配到的最后一個字符;意思就是前瞻不能阻止+對最后一個字符之前的所有字符進行貪婪匹配。
/<.+(?!def).+>/.exec("<abcdef>\n<abczzz>")
第一個 .+ 匹配到了 abcde,之后是 f,不是 def,第二個 .+ 匹配 f,符合正則
額外記錄
/(\d+)(?!\.1)/.exec("123.141") 目測是這樣的: > 123:\d+貪婪匹配到.為止 > 12:發(fā)現(xiàn) 123.1 不符合(?!\.1),后退一位 > 沒有表達式了,返回 12 /(.+)(?!\.1)/.exec("123.141") 目測是這樣的: > 123.141:.+貪婪匹配到結(jié)尾 > 123.141 : 符合(?!\.1) > 沒有表達式了,返回 123.141 /(.(?!\.1))+/.exec("123.141") 目測是這樣的: > 1:.匹配到新的一位 > 1:123 符合(?!\.1) > 12:.匹配到新的一位 > 12:123.符合(?!\.1) > 123:.匹配到新的一位 > 12:發(fā)現(xiàn) 123.1 不符合(?!\.1),后退一位,并退出循環(huán) > 沒有表達式了,返回 12
如果要對每個字符進行前瞻檢查,唯有最后一種寫法比較好理解。
以上是“正則表達式后面不要包含指定字符串內(nèi)容的示例分析”這篇文章的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對大家有幫助,更多相關(guān)知識,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!
網(wǎng)頁標題:正則表達式后面不要包含指定字符串內(nèi)容的示例分析
分享鏈接:http://chinadenli.net/article32/ihispc.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供外貿(mào)網(wǎng)站建設(shè)、定制開發(fā)、軟件開發(fā)、云服務(wù)器、、服務(wù)器托管
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)