正規表示式測試工具 MySql中正規表示式的使用方法描述

WBOY
發布: 2016-07-29 08:38:34
原創
965 人瀏覽過

正規表示式定義了一個字串的規則。最簡單的正規表示式不包含任何保留字。例如,正規表示式hello只和字串“hello”相符。 
一般的正規表示式使用了某些特殊的結構,所以它可以符合更多的字串。例如,正規表示式hello|word既能符合字串「hello」也能符合字串 「word」。舉一個更複雜一點的例子,正規表示式b[an]*s可以匹配字串「bananas」、「baaaaas」 、「bs」以及其他任何以b開頭以s結尾的字串,中間可以包括任意個a和任一個n的組合。
一個正規表示式中的可以使用以下保留字 

所符合的字串以後面的字串開頭 
mysql> select "fonfo" regexp "^fo$"; -> 0(表示不符) 
mysql> select "fofo" regexp "^fo"; -> 1(表示符合) 

所符合的字串以前面的字串結尾> select "fono" regexp "^fono$"; -> 1(表示匹配) 
mysql> select "fono" regexp "^fo$"; -> select "fono" regexp "^fo$"; -> 0(表示不符)  .匹配任何字元(包括新行) 
mysql> select "fofo" regexp "^f.*"; -> 1(表示匹配) 
mysql> select "fonfo" regexp 
mysql> select "fonfo" regexp "^f.*"; > 1(表示符合) 
a* 
符合任意多個a(包括空白串) 
mysql> select "ban" regexp "^ba*n"; -> 1(表示符合) 
mysql> select "baaan" regexp "^ba*n"; -> 1(表示符合) 
mysql> select "bn" regexp "^ba*n"; -> 1(表示符合) a> a> a>
符合任意多個a(不包括空串) 
mysql> select "ban" regexp "^ba+n"; -> 1(表示匹配) 
mysql> select "bn""> 1(表示匹配) 
mysql> select "bn" ba+n"; -> 0(表示不符) 
a? 
匹配一個或零個a 
mysql> select "bn" regexp "^ba?n"; -> select "bn" regexp "^ba?n"; -> 1(表示匹配) 
mysql> select "ban" regexp "^ba?n"; -> 1(表示符合) 
mysql> select "baan" regexp "^ba?n"; -> select "baan" regexp "^ba?n"; -> >
de|abc 
匹配de或abc 
mysql> select "pi" regexp "pi|apa"; -> 1(表示匹配)   0(表示不符) 
mysql> select "apa" regexp "pi|apa"; -> 1(表示符合) 
mysql> select "apa" $"; -> 1(表示匹配) 
mysql> select "pi" regexp "^(pi|apa)$"; -> 1(表示匹配) 
mysql> select "pix" 1(表示匹配) 
mysql> select "pix" pi|apa)$"; -> 0(表示不符) 
(abc)* 
任意多個abc(包括空串) 
mysql> select "pi" regexp "^(pi) *$"; -> 1(表示符合) 
mysql> select "pip" regexp "^(pi)*$"; -> 0(表示不符合) 
my (pi)*$"; -> 1(表示匹配) 
{1} 
{2,3} 
這是一個更全面的方法,它可以實現前面好幾種保留字的功能
a* 
可以寫成a{0,} 
a+ 
可以寫成a{1,} 
a? 
可以寫成a{0,1} 
在{ }內只有一個整數參數i,表示字元只能出現i次;在{}內有一個整型參數i,後面跟一個“,”,表示字元可以出現i次或i次以上;在{}內只有一個整型參數i,後面跟一個“,”,再跟一個整型參數j,表示字元只能出現i次以上,j次以下(包括i次和j次)。其中的整數參數必須大於等於0,小於等於 re_dup_max(預設為255)。若有兩個參數,第二個必須大於等於第一個 
[a-dx] 
配對「a」、「b」、「c」、「d」或「x」 
[ ^a-dx] 
符合除「a」、「b」、「c」、「d」、「x」以外的任何字元。「[」、「]」必須成對使用 
mysql> select "axbc" regexp "[a-dxyz]"; -> 1(表示符合) 
mysql> select "axbc" -dxyz]$"; -> 0(表示不符) 
mysql> select "axbc" regexp "^[a-dxyz]+$"; -> 1(表示符合) 
mysql> " regexp "^[^a-dxyz]+$"; -> 0(表示不符) 
mysql> select "gheis" regexp "^[^a-dxyz]+$"; -> 1(表示匹配) 
mysql> select "gheisa" regexp "^[^a-dxyz]+$"; -> 0(表示不符) 
---------------- -------------------------------------------- 
[[. characters.]] 
表示比較元素的順序。在括號內的字元順序是唯一的。但是括號中可以包含通配符, 所以他能匹配更多的字元。舉例來說:正規表示式[[.ch.]]*c符合chchcc的前五個字元。 
[=character_class=] 
表示相等的類,可以取代類中其他相等的元素,包括它自己。例如,如果o和(+)是一個相等的類別的成員,那麼[[=o=]]、[[=(+)=]]和[o(+)]是完全等價的。 
[:character_class:] 
在括號裡面,在[:和:]中間是字元類別的名字,可以代表屬於這個類別的所有字元。
字符類別的名字有: alnum、digit、punct、alpha、graph、space、blank、lower、upper、cntrl、print和xdigit 
mysql> select "justalnums" regexp:"[[[alnumsql :"[[alnumsql +"; -> 1(表示符合) 
mysql> select "!!" regexp "[[:alnum:]]+"; -> 0(表示不符合) 
[[::]] 
分別符合一個單字開頭和結尾的空的字串,這個單字開頭和結尾都不是包含在alnum中的字元也不能是底線。
mysql> select "a word a" regexp "[[::]]"; -> 1(表示符合) 
mysql> select "a xword a" regexp > 0(表示不符) 
mysql> select "weeknights" regexp "^(wee|week)(knights|nights)$"; -> 1(表示符合)

以上就介紹了正規表示式測試工具 MySql中正規表示式的使用方法描述,包括了正規表示式測試工具方面的內容,希望對PHP教學有興趣的朋友有所幫助。

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板