一.正則表達(dá)式語法(Perl風(fēng)格)
創(chuàng)新互聯(lián)公司專注于凱里網(wǎng)站建設(shè)服務(wù)及定制,我們擁有豐富的企業(yè)做網(wǎng)站經(jīng)驗(yàn)。 熱誠為您提供凱里營銷型網(wǎng)站建設(shè),凱里網(wǎng)站制作、凱里網(wǎng)頁設(shè)計(jì)、凱里網(wǎng)站官網(wǎng)定制、微信平臺小程序開發(fā)服務(wù),打造凱里網(wǎng)絡(luò)公司原創(chuàng)品牌,更為您提供凱里網(wǎng)站排名全網(wǎng)營銷落地服務(wù)。Perl一直被認(rèn)為是最偉大的解析語言之一,它提供了一種全面的正則表達(dá)式,即使是最復(fù)雜的字符串模式,也可以用這種正則表達(dá)式語言搜索和替換。PHP開發(fā)人員認(rèn)識到,與其重新發(fā)明正則表達(dá)式,不如讓PHP用戶直接使用聲名赫赫的Perl正則表達(dá)式語言,即Perl風(fēng)格的函數(shù)。
模式規(guī)則:/php/ 在字符串前后加上兩條斜杠即可。
匹配函數(shù):preg_match()函數(shù)在字符串中搜索模式,如果存在則返回true,否則返回false。
preg_match('/php/','php123'); //返回1 模式匹配
?>
二.正則表達(dá)式中的元素
正則表達(dá)式中包含三種元素分別為:量詞、元字符、修飾符
量詞
語法 | 描述 |
+ | 匹配任何至少包含一個(gè)前導(dǎo)字符串 |
* | 匹配任何包含零個(gè)或多個(gè)前導(dǎo)字符串 |
? | 匹配任何包含零個(gè)或一個(gè)前導(dǎo)字符串 |
. | 匹配任意字符串 |
{x} | 匹配任何包含x個(gè)前導(dǎo)字符串 |
{x,y} | 匹配任何包含x到y(tǒng)個(gè)前導(dǎo)字符串 |
{x,} | 匹配任何包含至少x個(gè)前導(dǎo)字符串 |
$ | 匹配字符串的行尾 |
^ | 匹配字符串的行首 |
| | 匹配字符串的左邊或者右邊 |
() | 包圍一個(gè)字符分組或定義個(gè)反引用,可以使用\1\2提取 |
元字符
語法 | 描述 |
[a-z] | 匹配任何包含小寫字母a-z的字符串 |
[A-Z] | 匹配任何包含大寫字母A-Z的字符串 |
[0-9] | 匹配任何包含數(shù)字0-9的字符串 |
[abc] | 匹配任何包含小寫字母a、b、c的字符串 |
[^abc] | 匹配任何不包含小寫字母a、b、c的字符串 |
[a-zA-Z0-9_] | 匹配任何包含a-zA-Z0-9和下劃線的字符串 |
\w | 匹配任何包含a-zA-Z0-9和下劃線的字符串(同上) |
\W | 匹配任何沒有下劃線和字母數(shù)字的字符串 |
\d | 匹配任何數(shù)字字符,和[0-9]相同 |
\D | 匹配任何非數(shù)字字符,和[^0-9]相同 |
\s | 匹配任何空白字符 |
\S | 匹配任何非空白字符 |
\b | 匹配是否到達(dá)了單詞邊界 |
\B | 匹配是否沒有達(dá)到單詞邊界 |
\ | 匹配正則中的特殊字符 |
修飾符
語法 | 描述 |
i | 完成不區(qū)分大小寫的搜索 |
m | 在匹配首內(nèi)容或者尾內(nèi)容時(shí)候采用多行識別匹配 |
x | 忽略正則中的空白 |
A | 強(qiáng)制從頭開始匹配 |
U | 禁止貪婪匹配 只跟蹤到最近的一個(gè)匹配符并結(jié)束 |
三.Perl風(fēng)格函數(shù)
PHP為使用Perl兼容的正則表達(dá)式搜索字符串提供了7個(gè)函數(shù),包括:preg_grep()、preg_match()、preg_match_all()、preg_auote()、preg_replace()、preg_replace_callback()和preg_split()。
搜索字符串:preg_grep()函數(shù)搜索數(shù)組中的所有元素,返回由與某個(gè)模式匹配的所有元素組成的數(shù)組。
$language=array('php','asp','jsp','python','ruby');
print_r(preg_grep('/p$/',$language));
?>
搜索模式:preg_match()函數(shù)在字符串中搜索模式,如果存在則返回true,否則返回false。
echopreg_match('/php[1-6]/','php5');
?>
電子郵件驗(yàn)證小案例(分組應(yīng)用)
$mode='/([\w\.\_]{2,10})@(\w{1,}).([a-z]{2,4})/';
$string='yc60.com@gmail.com';
echopreg_match($mode,$string);
?>
匹配模式的所有出現(xiàn):preg_match_all()函數(shù)在字符串中匹配模式的所有出現(xiàn),然后將所有匹配到的全部放入數(shù)組。
preg_match_all('/php[1-6]/','php5sdfphp4sdflljkphp3sdlfjphp2',$out);
print_r($out);
?>
定界特殊的正則表達(dá)式:preg_quote()在每個(gè)對于正則表達(dá)式語法而言有特殊含義的字符前插入一個(gè)反斜線。這些特殊字符包含:$ ^ * () + = {} [] | \\ : <>。
echopreg_quote('PHP的價(jià)格是:$150');
?>
替換模式的所有出現(xiàn):preg_replace()函數(shù)搜索到所有匹配,然后替換成想要的字符串返回出來。
echopreg_replace('/php[1-6]/','python','This is a php5,This is a php4');
?>
ubb小案例:貪婪問題+分組使用()
$mode='/\[b\](.*)\[\/b\]/U';
$replace='\1';
$string='This is a [b]php5[/b],This is a [b]php4[/b]';
echopreg_replace($mode,$replace,$string);
?>
以不區(qū)分大小寫的方式將字符串劃分為不同的元素:preg_split()用來分割不同的元素。
print_r(preg_split('/[\.@]/','yc60.com@gmail.com'));
?>
注:目前為PHP使用POSIX風(fēng)格的正則表達(dá)式搜索字符串提供了7個(gè)函數(shù),包括:ereg()、ereg_replace()、eregi()、eregi_replace()、split()、spliti()和sql_regcase()。
PS:和Perl風(fēng)格基本相同,可以參考手冊自行學(xué)習(xí)。
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)cdcxhl.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價(jià)比高”等特點(diǎn)與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場景需求。