關於正規表示式

2022-06-10 22:03:16 字數 3020 閱讀 1663

關於正規表示式,其實我已經迷茫了很長一段時間了。

正規表示式:

正規表示式是一種特殊的字串模式,用於匹配一組字串,就好比用模具做產品,而正則就是這個模具,定義一種規則去匹配符合規則的字元。

"^":^會匹配行或者字串的起始位置,有時還會匹配整個文件的起始位置。 

"$":$會匹配行或字串的結尾

"\b":不會消耗任何字元只匹配乙個位置,常用於匹配單詞邊界 如 我想從字串中"this is regex"匹配單獨的單詞 "is" 正則就要寫成 "\bis\b"  

\b 不會匹配is 兩邊的字元,但它會識別is 兩邊是否為單詞的邊界 

"\d": 匹配數字,

例如要匹配乙個固定格式的**號碼以0開頭前4位後7位,如0737-5686123  正則:^0\d\d\d-\d\d\d\d\d\d\d$ 這裡只是為了介紹"\d"字元,實際上有更好的寫法會在     下面介紹。

"\w":匹配字母,數字,下劃線.

例如我要匹配"a2345bcd__ttz" 正則:"\w+"  這裡的"+"字元為乙個量詞指重複的次數,稍後會詳細介紹。

"\s":匹配空格 

例如字元 "a b c" 正則:"\w\s\w\s\w"  乙個字元後跟乙個空格,如有字元間有多個空格直接把"\s" 寫成 "\s+" 讓空格重複

".":匹配除了換行符以外的任何字元

這個算是"\w"的加強版了"\w"不能匹配 空格 如果把字串加上空格用"\w"就受限了,看下用 "."是如何匹配字元"a23 4 5 b c d__ttz"  正則:".+"

"[abc]": 字元組  匹配包含括號內元素的字元 

這個比較簡單了只匹配括號內存在的字元,還可以寫成[a-z]匹配a至z的所以字母就等於可以用來控制只能輸入英文了,

寫法很簡單改成大寫就行了,意思與原來的相反,這裡就不舉例子了

"\w"匹配任意不是字母,數字,下劃線 的字元

"\s"匹配任意不是空白符的字元

"\d"匹配任意非數字的字元

"\b"匹配不是單詞開頭或結束的位置

"[^abc]"匹配除了abc以外的任意字元

先解釋關於量詞所涉及到的重要的三個概念

貪婪(貪心) 如"*"字元 貪婪量詞會首先匹配整個字串,嘗試匹配時,它會選定盡可能多的內容,如果 失敗則回退乙個字元,然後再次嘗試回退的過程就叫做回溯,它會每次回退乙個字元,直到找到匹配的內容或者沒有字元可以回退。相比下面兩種貪婪量詞對資源的消耗是最大的,

懶惰(勉強) 如 "?"  懶惰量詞使用另一種方式匹配,它從目標的起始位置開始嘗試匹配,每次檢查乙個字元,並尋找它要匹配的內容,如此迴圈直到字元結尾處。

占有  如"+" 占有量詞會覆蓋事個目標字串,然後嘗試尋找匹配內容 ,但它只嘗試一次,不會回溯,就好比先抓一把石頭,然後從石頭中挑出**

"*"(貪婪)重複零次或更多

例如"aaaaaaaa" 匹配字串中所有的a  正則: "a*"   會出到所有的字元"a"

"+"(懶惰)重複一次或更多次

例如"aaaaaaaa" 匹配字串中所有的a  正則: "a+"  會取到字元中所有的a字元,  "a+"與"a*"不同在於"+"至少是一次而"*" 可以是0次,

稍後會與"?"字元結合來體現這種區別

"?"(占有)重複零次或一次

例如"aaaaaaaa" 匹配字串中的a 正則 : "a?" 只會匹配一次,也就是結果只是單個字元a

""重複n次

例如從"aaaaaaaa" 匹配字串的a 並重複3次 正則:  "a"  結果就是取到3個a字元  "aaa";

""重複n到m次

例如正則 "a" 將a重複匹配3次或者4次 所以供匹配的字元可以是三個"aaa"也可以是四個"aaaa" 正則都可以匹配到

""重複n次或更多次

與不同之處就在於匹配的次數將沒有上限,但至少要重複n次 如 正則"a" a至少要重複3次

把量詞了解了之後之前匹配**號碼的正則現在就可以改得簡單點了^0\d\d\d-\d\d\d\d\d\d\d$ 可以改為"^0\d+-\d$"。

這樣寫還不夠完美如果因為前面的區號沒有做限定,以至於可以輸入很多們,而通常只能是3位或者4位,

現在再改一下 "^0\d-\d"如此一來區號部分就可以匹配3位或者4位的了

"*?"重複任意次,但盡可能少重複 

如 "acbacb"  正則  "a.*?b" 只會取到第乙個"acb" 原本可以全部取到但加了限定符後,只會匹配盡可能少的字元 ,而"acbacb"最少字元的結果就是"acb" 

"+?"重複1次或更多次,但盡可能少重複

與上面一樣,只是至少要重複1次

"??"重複0次或1次,但盡可能少重複

如 "aaacb" 正則 "a.??b" 只會取到最後的三個字元"acb"

"?"重複n到m次,但盡可能少重複

如 "aaaaaaaa"  正則 "a" 因為最少是0次所以取到結果為空

"?"重複n次以上,但盡可能少重複

如 "aaaaaaa"  正則 "a" 最少是1次所以取到結果為 "a"

關於正規表示式

前言 regular expressions 正規表示式,以下用re稱呼 對小弟來說一直都是神密的地帶,看到一些網路上的大大,簡單用re就決解了某些文字的問題,小弟便興起了學一學re的想法,但小弟天生就比較懶一些,總希望看有沒有些快速學習的方式,於是小弟又請出google大神,借由祂的神力,小弟在網...

關於正規表示式

使用atl中的正規表示式總是會多多少少的出問題,比如 不能識別,一些其他字元不能識別等等,所以使用了greta解決了那個問題 int caddmaker regexmatch cstring strs,cstring regex,cstringarray result match results r...

關於 正規表示式

網路程式設計中正規表示式的使用 最近開發涉及到很多網路程式設計和解析方面的,使用到正規表示式,剛開始一看,我暈,亂碼啊,這個到底是神馬啊。比如說下面這個東西 qregexp rx s 1234567890 正規表示式的概念就不仔細介紹,網上很多,也很清晰。下面只是此人個人觀點,與我本人無關,如有錯漏...