1. <ul id="0c1fb"></ul>

      <noscript id="0c1fb"><video id="0c1fb"></video></noscript>
      <noscript id="0c1fb"><listing id="0c1fb"><thead id="0c1fb"></thead></listing></noscript>

      99热在线精品一区二区三区_国产伦精品一区二区三区女破破_亚洲一区二区三区无码_精品国产欧美日韩另类一区

      RELATEED CONSULTING
      相關咨詢
      選擇下列產(chǎn)品馬上在線溝通
      服務時間:8:30-17:00
      你可能遇到了下面的問題
      關閉右側(cè)工具欄

      新聞中心

      這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
      正則表達式匹配不包含某些字符串的技巧有哪些-創(chuàng)新互聯(lián)

      這篇文章主要介紹了正則表達式匹配不包含某些字符串的技巧有哪些,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

      創(chuàng)新互聯(lián)聯(lián)系熱線:13518219792,為您提供成都網(wǎng)站建設網(wǎng)頁設計及定制高端網(wǎng)站建設服務,創(chuàng)新互聯(lián)網(wǎng)頁制作領域10多年,包括成都VR全景等多個領域擁有豐富的營銷推廣經(jīng)驗,選擇創(chuàng)新互聯(lián),為企業(yè)錦上添花。

      經(jīng)常我們會遇到想找出不包含某個字符串的文本,程序員最容易想到的是在正則表達式里使用,^(hede)來過濾”hede”字串,但這種寫法是錯誤的。我們可以這樣寫:[^hede],但這樣的正則表達式完全是另外一個意思,它的意思是字符串里不能包含‘h',‘e',‘d'三個但字符。那什么樣的正則表達式能過濾出不包含完整“hello”字串的信息呢?

      事實上,說正則表達式里不支持逆向匹配并不是百分之百的正確。就像這個問題,我們就可以使用否定式查找來模擬出逆向匹配,從而解決我們的問題:

      ^((?!hede).)*$

      上面這個表達式就能過濾出不包含‘hede'字串的信息。我上面也說了,這種寫法并不是正則表達式“擅長”的用法,但它是可以這樣用的。

      解釋

      一個字符串是由n個字符組成的。在每個字符之前和之后,都有一個空字符。這樣,一個由n個字符組成的字符串就有n+1個空字符串。我們來看一下“ABhedeCD”這個字符串:

      正則表達式匹配不包含某些字符串的技巧有哪些

      所有的e編號的位置都是空字符。表達式(?!hede).會往前查找,看看前面是不是沒有“hede”字串,如果沒有(是其它字符),那么.(點號)就會匹配這些其它字符。這種正則表達式的“查找”也叫做“zero-width-assertions”(零寬度斷言),因為它不會捕獲任何的字符,只是判斷。

      在上面的例子里,每個空字符都會檢查其前面的字符串是否不是‘hede',如果不是,這.(點號)就是匹配捕捉這個字符。表達式(?!hede).只執(zhí)行一次,所以,我們將這個表達式用括號包裹成組(group),然后用*(星號)修飾——匹配0次或多次:

      ((?!hede).)*。


      你可以理解,正則表達式((?!hede).)*匹配字符串"ABhedeCD"的結(jié)果false,因為在e3位置,(?!hede)匹配不合格,它之前有"hede"字符串,也就是包含了指定的字符串。

      在正則表達式里, ?! 是否定式向前查找,它幫我們解決了字符串“不包含”匹配的問題。

      以下是一些補充:

      分享下php生成隨機數(shù)的三種方法,生成1-10之間的不重復隨機數(shù),php生成不重復隨機數(shù)的例子,需要的朋友參考下。

      在hacker news上看到regex golf,幾道很有趣的正則表達式的題,有的需要用到不匹配這種匹配,比如需要匹配不包含某個單詞的串。

      開始正題之前,先來看看正則表達式的語法:

      [abc] a或b或c . 任意單個字符 a? 零個或一個a
      [^abc] 任意不是abc的字符 \s 空格 a* 零個或多個a
      [a-z] a-z的任意字符 \S 非空格 a+ 一個或多個a
      [a-zA-Z] a-z或A-Z \d 任意數(shù)字 a{n} 正好出現(xiàn)n次a
      ^ 一行開頭 \D 任意非數(shù)字 a{n,} 至少出現(xiàn)n次a
      $ 一行末尾 \w 任意字母數(shù)字或下劃線 a{n,m} 出現(xiàn)n-m次a
      (...) 括號用于分組 \W 任意非字母數(shù)字或下劃線 a*? 零個或多個a(非貪婪)
      (a|b) a或b \b 單詞邊界 (a)...\1 引用分組
      (?=a) 前面有a (?!a) 前面沒有a \B 非單詞邊界

      正則表達式中有(?=a)和(?!a)來表示我們是否需要匹配某個東西。

      所以,有需要不匹配某樣內(nèi)容時,就可以用(?!a)了。比如要匹配不含hello的字符串就可以這樣寫。


      ^(?!.*hello)


      這里.*用來表示hello之前可能有其他的字符,為什么還要加^呢,因為如果不加的話,可能匹配到h之后的這個位置上了。

      現(xiàn)在就可以解決regex golf上的abba這道題了。
      這道題是去匹配不含abba這種形式的單詞,比如abba,anallagmatic就不應該匹配上。

      正則表達式代碼:

      ^(?!.*(.)(.)\2\1)


      然后利用不匹配,還可以解決prime這道題,這道題匹配有素數(shù)個x的串,先看正則。

      ^(?!(xx+)\1+$)


      (xx+)是匹配2個及2個以上的x,(xx+)\1+就是匹配重復出現(xiàn)2個及以上的串,所以(xx+)\1+就表示了那些非素數(shù)的串,那么素數(shù)串就是除去這些非素數(shù)串,即是以上的正則表達式了。

      感謝你能夠認真閱讀完這篇文章,希望小編分享的“正則表達式匹配不包含某些字符串的技巧有哪些”這篇文章對大家有幫助,同時也希望大家多多支持創(chuàng)新互聯(lián)網(wǎng)站建設公司,,關注創(chuàng)新互聯(lián)行業(yè)資訊頻道,更多相關知識等著你來學習!


      當前文章:正則表達式匹配不包含某些字符串的技巧有哪些-創(chuàng)新互聯(lián)
      分享網(wǎng)址:http://www.ef60e0e.cn/article/dggoio.html
      99热在线精品一区二区三区_国产伦精品一区二区三区女破破_亚洲一区二区三区无码_精品国产欧美日韩另类一区
      1. <ul id="0c1fb"></ul>

        <noscript id="0c1fb"><video id="0c1fb"></video></noscript>
        <noscript id="0c1fb"><listing id="0c1fb"><thead id="0c1fb"></thead></listing></noscript>

        多伦县| 合作市| 衡阳市| 威信县| 枣阳市| 武汉市| 汤原县| 察哈| 赤城县| 阿尔山市| 繁昌县| 宁都县| 涪陵区| 会泽县| 依安县| 天柱县| 屏东县| 封开县| 赞皇县| 扎囊县| 乌苏市| 赤壁市| 河南省| 长宁县| 临武县| 内江市| 磐石市| 东宁县| 志丹县| 察雅县| 绥阳县| 中山市| 东至县| 日喀则市| 弋阳县| 磐石市| 郑州市| 富顺县| 资源县| 田林县| 西林县|