關於正規表示式,其實我已經迷茫了很長一段時間了。
正規表示式:
正規表示式是一種特殊的字串模式,用於匹配一組字串,就好比用模具做產品,而正則就是這個模具,定義一種規則去匹配符合規則的字元。
"^":^會匹配行或者字串的起始位置,有時還會匹配整個文件的起始位置。
"$":$會匹配行或字串的結尾
"\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 正規表示式的概念就不仔細介紹,網上很多,也很清晰。下面只是此人個人觀點,與我本人無關,如有錯漏...