主頁(yè) > 知識(shí)庫(kù) > php 正則表達(dá)式的子模式詳解

php 正則表達(dá)式的子模式詳解

熱門標(biāo)簽:自己做的電銷機(jī)器人 惠安地圖標(biāo)注 山東外呼系統(tǒng)聯(lián)系方式 浙江營(yíng)銷外呼系統(tǒng)有哪些 上海銷售電銷機(jī)器人軟件 遼寧秒客來(lái)電話機(jī)器人 淄博市張店區(qū)地圖標(biāo)注 哈爾濱公司外呼系統(tǒng)代理 地圖標(biāo)注店鋪地圖標(biāo)注酒店
首先,我們先看一段PHP代碼:

復(fù)制代碼 代碼如下:

?php
$time = date ("Y-m-d H:i:s");
$pattern = "/\d{4}-\d{2}-\d{2} \d{2}:\d{2}:\d{2}/i";
if(preg_match($pattern,$time,$arr)){
echo "pre>";
print_r($arr);
echo "/pre>";
}
?>

顯示結(jié)果:
復(fù)制代碼 代碼如下:

Array
(
[0] => 2012-06-23 03:08:45
)

有沒(méi)有注意到,顯示的結(jié)果只有一條數(shù)據(jù),即符合匹配模式的時(shí)間格式,那如果只有一條記錄的話,為什么還要用數(shù)組保存呢?直接使用字符串保存不是更好?

帶著這個(gè)問(wèn)題,我們來(lái)看下正則表達(dá)式中的子模式。

在正則表達(dá)式中,可以使用“(”和“)”將模式中的子字符串括起來(lái),以形成一個(gè)子模式。將子模式視為一個(gè)整體時(shí),那么它就相當(dāng)于一個(gè)單個(gè)字符。

比如,我們將以上的代碼稍微修改下,改成如下:
復(fù)制代碼 代碼如下:

?php
$time = date ("Y-m-d H:i:s");
$pattern = "/(\d{4})-(\d{2})-(\d{2}) (\d{2}):(\d{2}):(\d{2})/i";
if(preg_match($pattern,$time,$arr)){
echo "pre>";
print_r($arr);
echo "/pre>";
}
?>

注意:我只修改了$pattern,在匹配模式中,使用了括號(hào)()

執(zhí)行結(jié)果:

復(fù)制代碼 代碼如下:

Array
(
[0] => 2012-06-23 03:19:23
[1] => 2012
[2] => 06
[3] => 23
[4] => 03
[5] => 19
[6] => 23
)

總結(jié):我們可以使用小括號(hào)給整個(gè)匹配模式進(jìn)行分組,默認(rèn)情況下,每個(gè)分組會(huì)自動(dòng)擁有一個(gè)組號(hào),規(guī)則是,從左到右,以分組的左括號(hào)為標(biāo)志,第一個(gè)出現(xiàn)的分組為組號(hào)1,第二個(gè)為組號(hào)2,以此類推。其中,分組0對(duì)應(yīng)整個(gè)正則表達(dá)式。對(duì)整個(gè)正則匹配模式進(jìn)行了分組以后,就可以進(jìn)一步使用“向后引用”來(lái)重復(fù)搜索前面的某個(gè)分組匹配的文本。例如:\1代表分組1匹配的文本,\2代表分組2匹配的文本等等我們可以進(jìn)一步修改下代碼,如下所示:
復(fù)制代碼 代碼如下:

?php
$time = date ("Y-m-d H:i:s");
$pattern = "/(\d{4})-(\d{2})-(\d{2}) (\d{2}):(\d{2}):(\d{2})/i";
$replacement = "\$time格式為:$0BR>替換后的格式為:\\1年\\2月\\3日 \\4時(shí)\\5分\\6秒";
print preg_replace($pattern, $replacement, $time);
if(preg_match($pattern,$time,$arr)){
echo "pre>";
print_r($arr);
echo "/pre>";
}
?>

注意:

因?yàn)槭窃陔p引號(hào)中,所以使用分組的時(shí)候應(yīng)該使用兩個(gè)反斜杠,如:\\1,而如果在單引號(hào)中,則使用一個(gè)反斜杠就可以了,如:\1
\\1用于捕獲分組一種的內(nèi)容:2012,\\6用于捕獲分組6中的內(nèi)容          
執(zhí)行結(jié)果:


$time格式為:2012-06-23 03:30:31
替換后的格式為:2012年06月23日 03時(shí)30分31秒
復(fù)制代碼 代碼如下:

Array
(
[0] => 2012-06-23 03:30:31
[1] => 2012
[2] => 06
[3] => 23
[4] => 03
[5] => 30
[6] => 31
)
您可能感興趣的文章:
  • js使用正則子表達(dá)式匹配首字母與尾字母相同單詞的方法
  • 正則表達(dá)式、分組、子匹配(子模式)、非捕獲子匹配(子模式)
  • 深入分析正則表達(dá)式的子模式
  • 僅1個(gè)例子輕松學(xué)習(xí)正則表達(dá)式
  • PHP正則表達(dá)式的逆向引用與子模式分析
  • 正則表達(dá)式教程之位置匹配詳解
  • 正則表達(dá)式教程之重復(fù)匹配詳解
  • 正則表達(dá)式教程之元字符的使用詳解
  • 正則表達(dá)式教程之匹配一組字符詳解
  • 正則表達(dá)式教程之匹配單個(gè)字符詳解
  • 正則表達(dá)式教程之操作符及說(shuō)明詳解
  • 正則表達(dá)式教程之子表達(dá)式用法分析

標(biāo)簽:銅川 泰州 重慶 綿陽(yáng) 無(wú)錫 宣城 西安 長(zhǎng)沙

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《php 正則表達(dá)式的子模式詳解》,本文關(guān)鍵詞  php,正則,表達(dá)式,的,子,模式,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《php 正則表達(dá)式的子模式詳解》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于php 正則表達(dá)式的子模式詳解的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章