正規表示式定義了一個字串的規則。最簡單的正規表示式不包含任何保留字。例如,正規表示式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教學有興趣的朋友有所幫助。