婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > 寫出高效率的正則表達式技巧總結

寫出高效率的正則表達式技巧總結

熱門標簽:實用地圖標注app 菏澤智能ai電銷機器人銷售公司 400免費電話去哪申請 地圖標注商戶中心要收錢多少 線上教育ai外呼系統 地圖標注字母的軟件 鄂州人工智能電銷機器人軟件 宿遷智能外呼系統供應商 css百度地圖標注位置顯示

如果純粹是為了挑戰自己的正則水平,用來實現一些特效(例如使用正則表達式計算質數、解線性方程),效率不是問題;如果所寫的正則表達式只是為了滿足一兩次、幾十次的運行,優化與否區別也不太大。但是,如果所寫的正則表達式會百萬次、千萬次地運行,效率就是很大的問題了。

 為行文方便,先定義兩個概念。
誤匹配:指正則表達式所匹配的內容范圍超出了所需要范圍,有些文本明明不符合要求,但是被所寫的正則式“擊中了”。例如,如果使用\d{11}來匹配11位的手機號,\d{11}不單能匹配正確的手機號,它還會匹配98765432100這樣的明顯不是手機號的字符串。我們把這樣的匹配稱之為誤匹配。
漏匹配:指正則表達式所匹配的內容所規定的范圍太狹窄,有些文本確實是所需要的,但是所寫的正則沒有將這種情況囊括在內。例如,使用\d{18}來匹配18位的身份證號碼,就會漏掉結尾是字母X的情況。
寫出一條正則表達式,既可能只出現誤匹配(條件寫得極寬松,其范圍大于目標文本),也可能只出現漏匹配(只描述了目標文本中多種情況種的一種),還可能既有誤匹配又有漏匹配。例如,使用\w+\.com來匹配.com結尾的域名,既會誤匹配abc_.com這樣的字串(合法的域名中不含下劃線,\w包含了下劃線這種情況),又會漏掉ab-c.com這樣的域名(合法域名中可以含中劃線,但是\w不匹配中劃線)。
精準的正則表達式意味著既無誤匹配且無漏匹配。當然,現實中存在這樣的情況:只能看到有限數量的文本,根據這些文本寫規則,但是這些規則將會用到海量的文本中。這種情況下,盡可能地(如果不是完全地)消除誤匹配以及漏匹配,并提升運行效率,就是我們的目標。本文所提出的經驗,主要是針對這種情況。
掌握語法細節。正則表達式在各種語言中,其語法大致相同,細節各有千秋。明確所使用語言的正則的語法的細節,是寫出正確、高效正則表達式的基礎。例如,perl中與\w等效的匹配范圍是[a-zA-Z0-9_];perl正則式不支持肯定逆序環視中使用可變的重復(variable repetition inside lookbehind,例如(?=.*)abc),但是.Net語法是支持這一特性的;又如,JavaScript連逆序環視(Lookbehind,如(?=ab)c)都不支持,而perl和python是支持的。《精通正則表達式》第3章《正則表達式的特性和流派概覽》明確地列出了各大派系正則的異同,這篇文章也簡要地列出了幾種常用語言、工具中正則的比較。對于具體使用者而言,至少應該詳細了解正在使用的那種工作語言里正則的語法細節。
先粗后精,先加后減。使用正則表達式語法對于目標文本進行描述和界定,可以像畫素描一樣,先大致勾勒出框架,再逐步在局步實現細節。仍舉剛才的手機號的例子,先界定\d{11},總不會錯;再細化為1[358]\d{9},就向前邁了一大步(至于第二位是不是3、5、8,這里無意深究,只舉這樣一個例子,說明逐步細化的過程)。這樣做的目的是先消除漏匹配(剛開始先盡可能多地匹配,做加法),然后再一點一點地消除誤匹配(做減法)。這樣有先有后,在考慮時才不易出錯,從而向“不誤不漏”這個目標邁進。
留有余地。所能看到的文本sample是有限的,而待匹配檢驗的文本是海量的,暫時不可見的。對于這樣的情況,在寫正則表達式時要跳出所能見到的文本的圈子,開拓思路,作出“戰略性前瞻”。例如,經常收到這樣的垃圾短信:“發*票”、“發#漂”。如果要寫規則屏蔽這樣煩人的垃圾短信,不但要能寫出可以匹配當前文本的正則表達式 發[*#](?:票|漂),還要能夠想到 發.(?:票|漂|飄)之類可能出現的“變種”。這在具體的領域或許會有針對性的規則,不多言。這樣做的目的是消除漏匹配,延長正則表達式的生命周期。
明確。具體說來,就是謹慎用點號這樣的元字符,盡可能不用星號和加號這樣的任意量詞。只要能確定范圍的,例如\w,就不要用點號;只要能夠預測重復次數的,就不要用任意量詞。例如,寫析取twitter消息的腳本,假設一條消息的xml正文部分結構是span class=”msg”>…/span>且正文中無尖括號,那么span class=”msg”>[^]{1,480}/span>這種寫法的思路要好于span class=”msg”>.*/span>,原因有二:一是使用[^],它保證了文本的范圍不會超出下一個小于號所在的位置;二是明確長度范圍,{1,480},其依據是一條twitter消息大致能的字符長度范圍。當然,480這個長度是否正確還可推敲,但是這種思路是值得借鑒的。說得狠一點,“濫用點號、星號和加號是不環保、不負責任的做法”。
不要讓稻草壓死駱駝。每使用一個普通括號()而不是非捕獲型括號(?:…),就會保留一部分內存等著你再次訪問。這樣的正則表達式、無限次地運行次數,無異于一根根稻草的堆加,終于能將駱駝壓死。養成合理使用(?:…)括號的習慣。
寧簡勿繁。將一條復雜的正則表達式拆分為兩條或多條簡單的正則表達式,編程難度會降低,運行效率會提升。例如用來消除行首和行尾空白字符的正則表達式s/^\s+|\s+$//g;,其運行效率理論上要低于s/^\s+//g; s/\s+$//g; 。這個例子出自《精通正則表達式》第五章,書中對它的評論是“它幾乎總是最快的,而且顯然最容易理解”。既快又容易理解,何樂而不為?工作中我們還有其它的理由要將C==(A|B)這樣的正則表達式拆為A和B兩條表達式分別執行。例如,雖然A和B這兩種情況只要有一種能夠擊中所需要的文本模式就會成功匹配,但是如果只要有一條子表達式(例如A)會產生誤匹配,那么不論其它的子表達式(例如B)效率如何之高,范圍如何精準,C的總體精準度也會因A而受到影響。
巧妙定位。有時候,我們需要匹配的the,是作為單詞的the(兩邊有空格),而不是作為單詞一部分的t-h-e的有序排列(例如together中的the)。在適當的時候用上^,$,\b等等定位錨點,能有效提升找到成功匹配、淘汰不成功匹配的效率。

以上就是總結了幾條提升正則表達式運行效率的經驗(工作中學到的,看書學來的,自己的體會),整理在這里。如果您有其它的經驗而這里沒有提及,歡迎討論。

您可能感興趣的文章:
  • 正則表達式高級學習技巧
  • ASP正則表達式技巧
  • PHP 正則表達式的幾則使用技巧
  • 正則表達式高級技巧及實例詳解 笨活兒
  • javascript 正則表達式(二) 使用技巧說明
  • 模板引擎正則表達式調試小技巧
  • 正則表達式的高級技巧分享
  • .NET 正則表達式使用高級技巧之替換類介紹
  • 正則表達式匹配不包含某些字符串的技巧

標簽:六安 恩施 綿陽 梅州 三亞 池州 咸陽 鞍山

巨人網絡通訊聲明:本文標題《寫出高效率的正則表達式技巧總結》,本文關鍵詞  寫出,高效率,的,正則,表達式,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《寫出高效率的正則表達式技巧總結》相關的同類信息!
  • 本頁收集關于寫出高效率的正則表達式技巧總結的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    欧美群妇大交群中文字幕| 日本欧美加勒比视频| 国产一区二区视频在线| 3d动漫精品啪啪一区二区竹菊| 国产欧美日韩另类视频免费观看| 91丝袜美女网| 国产麻豆精品视频| 亚洲视频在线观看一区| 欧美日韩国产另类一区| 国产资源在线一区| 黑人精品欧美一区二区蜜桃| 亚洲成人免费视频| 婷婷六月综合网| 五月天亚洲精品| 亚洲成国产人片在线观看| 亚洲综合色成人| 亚洲综合在线视频| 亚洲香肠在线观看| 亚洲自拍偷拍综合| 日本欧美在线观看| 国产精品18久久久久久久久| 波多野结衣中文字幕一区 | 中文字幕亚洲一区二区va在线| 久久综合给合久久狠狠狠97色69| 欧美精品一区二区三| 国产精品萝li| 亚洲乱码国产乱码精品精的特点 | 日韩一级黄色片| 欧美国产综合色视频| 亚洲福利一区二区| 激情国产一区二区| 在线观看日韩一区| 精品久久久久久久一区二区蜜臀| 亚洲欧洲国产日本综合| 蜜桃av一区二区在线观看| 99久久久久久| 在线国产电影不卡| 久久久久久久久久久久久夜| 亚洲国产精品久久久男人的天堂| 激情五月激情综合网| 欧美精品久久99久久在免费线| 欧美日韩在线电影| 国产精品久久毛片| 美国毛片一区二区| 欧美高清一级片在线| 中文字幕成人在线观看| 男人的j进女人的j一区| 在线观看亚洲a| 樱桃国产成人精品视频| 99久久婷婷国产精品综合| 日韩欧美国产精品一区| 日本伊人午夜精品| 成人黄色综合网站| 91精品国产色综合久久| www.久久久久久久久| 亚洲视频网在线直播| 91免费小视频| 亚洲国产精品t66y| 韩国欧美国产1区| 26uuu精品一区二区在线观看| 亚洲精品自拍动漫在线| 欧美亚洲国产一区在线观看网站| 亚洲免费av高清| 欧美综合在线视频| 中文字幕亚洲不卡| 97精品视频在线观看自产线路二 | www久久精品| 国精产品一区一区三区mba桃花| 日韩欧美一二三四区| 亚洲1区2区3区4区| 亚洲精品在线观看视频| 婷婷中文字幕一区三区| 日韩欧美国产一区二区在线播放| 久久精品国产亚洲a| 国产婷婷精品av在线| 国产精品2024| 午夜日韩在线电影| www国产精品av| 在线观看三级视频欧美| 久久国产麻豆精品| 国产精品不卡一区二区三区| 91麻豆精品国产91久久久使用方法| 国产精一区二区三区| 亚洲大片免费看| 国产精品国产三级国产有无不卡 | 九九九久久久精品| 国产欧美一区二区三区在线老狼| 成人激情开心网| 日韩一区精品视频| 精品国产麻豆免费人成网站| 国产成人精品影院| 亚洲444eee在线观看| 丰满放荡岳乱妇91ww| 日本一区二区视频在线观看| 91网站最新网址| 亚洲va韩国va欧美va| 怡红院av一区二区三区| 久久婷婷一区二区三区| 欧美日韩国产123区| 久久国产精品第一页| 国产成人啪午夜精品网站男同| 欧美激情一区二区三区在线| 丁香婷婷综合五月| 国产精品电影一区二区| 国产精品一区在线| 在线日韩一区二区| 久久夜色精品一区| 91精品蜜臀在线一区尤物| 国产麻豆精品久久一二三| 色综合久久天天| 日韩手机在线导航| 久久精品国产99国产| 欧美一区二区成人6969| 色婷婷综合久久| 夜夜嗨av一区二区三区网页| 91九色最新地址| 色婷婷精品久久二区二区蜜臂av| 国产日产亚洲精品系列| 精品国产一区二区国模嫣然| 26uuu精品一区二区| 日韩免费一区二区| 日韩免费观看高清完整版| 国产日本欧洲亚洲| www亚洲一区| 久久久蜜臀国产一区二区| 香蕉乱码成人久久天堂爱免费| 久久久不卡网国产精品一区| 波多野结衣精品在线| 91一区二区三区在线播放| 欧美区一区二区三区| 色呦呦一区二区三区| 91免费视频网址| 欧美性受极品xxxx喷水| 成人免费av资源| 91精品国产色综合久久| 国产精品国产三级国产普通话蜜臀 | 国产精品久久夜| 亚洲色图制服诱惑| 美国av一区二区| 成人免费视频视频| 一本大道久久精品懂色aⅴ | 国产做a爰片久久毛片| 欧美久久久久久久久中文字幕| 久久精品夜色噜噜亚洲aⅴ| 丝袜美腿成人在线| 99久精品国产| 91小视频免费看| 亚洲色图在线看| 国产99久久久国产精品免费看 | 成人午夜激情影院| 久久影院视频免费| 亚洲成人在线观看视频| 亚洲精品老司机| 国产精品一二二区| 成熟亚洲日本毛茸茸凸凹| 日韩欧美另类在线| 婷婷综合另类小说色区| 欧美日本在线看| 免费精品视频最新在线| 欧美一区二区三区婷婷月色| 天天操天天干天天综合网| 成人午夜在线视频| 一二三区精品视频| 欧美日韩国产综合视频在线观看| 欧美日韩亚洲另类| 亚洲欧洲精品一区二区三区| 成人av免费网站| 久久亚洲综合av| 成人免费毛片嘿嘿连载视频| 日韩欧美精品在线视频| 亚洲成人免费电影| 久久精品av麻豆的观看方式| 国产精品久久久久久久久久久免费看 | av激情成人网| 久久综合成人精品亚洲另类欧美| 91在线高清观看| 午夜激情一区二区| 国产丝袜在线精品| 欧美一级xxx| 91丝袜国产在线播放| 国产毛片精品视频| 悠悠色在线精品| 国产精品色婷婷| 日韩视频在线永久播放| 色偷偷一区二区三区| 99精品视频免费在线观看| 中文在线免费一区三区高中清不卡| 日本黄色一区二区| 欧美区一区二区三区| 蓝色福利精品导航| 欧美一区二区日韩一区二区| 国产一区二区福利| 国产欧美日韩不卡免费| 99精品欧美一区二区蜜桃免费| 精品在线亚洲视频| 五月天一区二区| 亚洲人成在线观看一区二区| 国产亚洲短视频| 日本中文在线一区| 欧美日韩国产区一|