a亚洲精品_精品国产91乱码一区二区三区_亚洲精品在线免费观看视频_欧美日韩亚洲国产综合_久久久久久久久久久成人_在线区

首頁 > 編程 > regex > 正文

詳解正則表達式后面不要包含指定的字符串內容

2020-01-20 21:58:53
字體:
來源:轉載
供稿:網友

以前只會/<abc(?!def).+>/.exec("<abcdef>/n<abczzz>"),匹配到<abczzz>,這種簡單的固定寫法,但實際使用次數幾乎趨近于0。

很多場景不能寫死abc,順理成章的就寫成了/<.+(?!def).+>/.exec("<abcdef>/n<abczzz>"),咦?咋把前面的匹配到了!從入門到放棄。

昨天(2019-04-07)隨手寫了一下/<(?:.(?!def))+>/.exec("<abcdef>/n<abczzz>"),原來是對.+(?!排除的字符串)這個結構能起到的作用理解錯了,怪不得達不到預期,(.(?!排除的字符串))+才是正解。

留下一個未解的問題,每個字符后面排除一下的能良好工作,一堆未定長度字符后排除一下怎么就不能工作,前瞻不會和前面的+、*、{}起作用嗎?解釋看結尾。

:/<(?!.+def).+>/.exec("<abcdefzzz>/n<abczzz>")寫法也可以。可能是結尾的.+導致的不能匹配,但這樣寫還是不行:/<.+(?!def)zzz>/.exec("<abcdefzzz>/n<abczzz>")。

正則表達式匹配指定內容后面要或不要包含指定的字符串內容:

•要:比較簡單,寫上這個要的即可
•不要:比要復雜很多,如何排除掉?

前提原則

1.表達式內固定內容的字符串能不寫盡量不寫,能簡寫的盡量簡化來寫(如前面寫的abc部分不能寫死)
2.可以少量使用前瞻(正向),后瞻(反向)基本不學,學了還要研究那些瀏覽器支持,不敢用,太多了也學不動。
3.NoJS(Not Only JavaScript);不僅僅是瀏覽器中的js;不過js的正則/exp/字面量寫法簡潔到沒盆友(哪個語言),函數、對象、字符串統統不需要;不接受反駁。

假設待匹配的文本

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>......`;//注: *** 不是固定內容,但不會出現未轉義的xml實體、matchX、excludeX//注: class=" matchX 123456"純文本只做演示干擾之用,不應當作為特征//如果數據對換行不敏感,應優先轉換成沒有換行的,大概率可以簡化正則邏輯htmlNoWrap=htmlRaw.replace(/[/r/n]+/g," ");//正則測試代碼(/[/s/S]*/.exec(htmlRaw)||[])[0]

不要單個字符的匹配

匹配出div.matchX標簽:<div ***="*** ***" class="*** matchX ***" ***="***">

可以直接使用 [^>]把matchX限定在<> HTML標記內,意思就是<>中的文本不要出現結尾的>字符。

單個字符還算簡單:

//有效/<div[^>]+matchX[^>]+>/.exec(htmlRaw)[0]

如果不限定在<>標記內,可能會匹配出界;并且這種不限定,遲早會出亂子:

//無效/<div.+?matchX.+?>/.exec(htmlNoWrap)[0]/<div[/s/S]+?matchX[/s/S]+?>/.exec(htmlRaw)[0] //有換行符就是又長又難看

其他單個字符場景另行靈活運用。

不要一個字符串的匹配

匹配出第一層不帶excludeX文本內容的第一塊div,就是返回包含matchX 4的那塊div

[^]語法只能排除掉單個字符,不要一個字符串咋辦?硬是要寫成[^abc],會把a、b、c字符全部排除掉;除了使用前瞻,好像還沒有別的簡單辦法。

使用本文開頭的(.(?!排除的字符串))+結構就能達到目的,核心就在(?:[^>](?!excludeX))*:

//有效/<div[^>]*>[^<]+<div(?:[^>](?!excludeX))*>[^<]+<//div>[^<]+<//div>/.exec(htmlRaw)[0]

要包含一個字符串的匹配,直接寫需要的字符串即可,相對簡單太多,就不寫這種例子了。

未研究(.(?!排除的字符串))+結構的性能。

對于.+(?!排除)不能工作的釋疑

由于(?!排除)并不會作用于貪婪匹配到的每一個字符串,只會作用于.+貪婪匹配到的最后一個字符;意思就是前瞻不能阻止+對最后一個字符之前的所有字符進行貪婪匹配。

/<.+(?!def).+>/.exec("<abcdef>/n<abczzz>")

第一個 .+ 匹配到了 abcde,之后是 f,不是 def,第二個 .+ 匹配 f,符合正則

額外記錄

/(/d+)(?!/.1)/.exec("123.141") 目測是這樣的:> 123:/d+貪婪匹配到.為止> 12:發現 123.1 不符合(?!/.1),后退一位> 沒有表達式了,返回 12/(.+)(?!/.1)/.exec("123.141") 目測是這樣的:> 123.141:.+貪婪匹配到結尾> 123.141 : 符合(?!/.1)> 沒有表達式了,返回 123.141/(.(?!/.1))+/.exec("123.141") 目測是這樣的:> 1:.匹配到新的一位> 1:123 符合(?!/.1)> 12:.匹配到新的一位> 12:123.符合(?!/.1)> 123:.匹配到新的一位> 12:發現 123.1 不符合(?!/.1),后退一位,并退出循環> 沒有表達式了,返回 12

如果要對每個字符進行前瞻檢查,唯有最后一種寫法比較好理解。

總結

以上所述是小編給大家介紹的正則表達式后面不要包含指定的字符串內容,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對武林網網站的支持!

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 欧美成人一区二区三区片免费 | 国产精品久久国产精品 | 中文字幕一区二区三区日韩精品 | 午夜精品久久久久久久久 | 91啦| 国产精品伦一区二区三级视频 | 亚洲精品久久久久久久久久 | 狠狠一区| 男女视频在线观看 | 国产区在线 | 四虎影视最新网址 | 欧美日韩在线视频一区 | 国产伦精品一区二区三区不卡视频 | 成人精品一区二区三区中文字幕 | 亚洲精品午夜视频 | 日韩精品成人 | 亚洲一区二区三区 | 中文字幕在线免费 | 亚洲一区av在线 | 91久久久精品视频 | 成人在线观 | 久久久久亚洲 | 国产精品久久久久高潮色老头 | 在线成人av | 国产精品福利久久 | 天天干天天搞天天射 | 中文成人无字幕乱码精品 | av国产精品 | 亚洲一区二区在线播放 | 色呦呦 | 日韩在线一区二区 | 九色91在线 | 精品在线一区二区三区 | 草视频在线| 中文字幕1区 | 亚洲 欧美 在线 一区 | 自拍视频网 | 欧美高清视频在线观看 | 日本天天色 | 欧美大片在线免费观看 | 国产精品久久国产精麻豆99网站 |