深入分析正則表達(dá)式的子模式
首先,我們先看一段PHP代碼:
<?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é)果:
Array ( [0] => 2012-06-23 03:08:45 )
有沒有注意到,顯示的結(jié)果只有一條數(shù)據(jù),即符合匹配模式的時間格式,那如果只有一條記錄的話,為什么還要用數(shù)組保存呢?直接使用字符串保存不是更好?
帶著這個問題,我們來看下正則表達(dá)式中的子模式。
在正則表達(dá)式中,可以使用“(”和“)”將模式中的子字符串括起來,以形成一個子模式。將子模式視為一個整體時,那么它就相當(dāng)于一個單個字符。
比如,我們將以上的代碼稍微修改下,改成如下:
<?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,在匹配模式中,使用了括號()
執(zhí)行結(jié)果:
Array ( [0] => 2012-06-23 03:19:23 [1] => 2012 [2] => 06 [3] => 23 [4] => 03 [5] => 19 [6] => 23 )
總結(jié):我們可以使用小括號給整個匹配模式進(jìn)行分組,默認(rèn)情況下,每個分組會自動擁有一個組號,規(guī)則是,從左到右,以分組的左括號為標(biāo)志,第一個出現(xiàn)的分組為組號1,第二個為組號2,以此類推。其中,分組0對應(yīng)整個正則表達(dá)式。
對整個正則匹配模式進(jìn)行了分組以后,就可以進(jìn)一步使用“向后引用”來重復(fù)搜索前面的某個分組匹配的文本。例如:\1代表分組1匹配的文本,\2代表分組2匹配的文本等等
我們可以進(jìn)一步修改下代碼,如下所示:
<?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格式為:$0<BR>替換后的格式為:\\1年\\2月\\3日 \\4時\\5分\\6秒"; print preg_replace($pattern, $replacement, $time); if(preg_match($pattern,$time,$arr)){ echo "<pre>"; print_r($arr); echo "</pre>"; } ?>
注意:
因為是在雙引號中,所以使用分組的時候應(yīng)該使用兩個反斜杠,如:\\1,而如果在單引號中,則使用一個反斜杠就可以了,如:\1
\\1用于捕獲分組一種的內(nèi)容:2012,\\6用于捕獲分組6中的內(nèi)容
執(zhí)行結(jié)果:
$time格式為:2012-06-23 03:30:31 替換后的格式為:2012年06月23日 03時30分31秒 Array ( [0] => 2012-06-23 03:30:31 [1] => 2012 [2] => 06 [3] => 23 [4] => 03 [5] => 30 [6] => 31 )
相關(guān)文章
js正則匹配table,img及去除各種標(biāo)簽問題
這篇文章主要介紹了js正則匹配table,img及去除各種標(biāo)簽問題,需要的朋友可以參考下2020-04-04使用正則表達(dá)式過濾 S3 上以 _$folder$ 結(jié)尾的占位文件的方法
當(dāng)我們使用命令行批量從 S3 上拷貝文件或統(tǒng)計文件數(shù)量時,希望能排除掉 S3 上以 _$folder$ 結(jié)尾的占位文件,這個正則表達(dá)式應(yīng)該怎么寫呢,本文給大家介紹使用正則表達(dá)式過濾 S3 上以 _$folder$ 結(jié)尾的占位文件的方法,感興趣的朋友一起看看吧2023-12-12正則表達(dá)式re.sub替換不完整的問題及完整解決方案
re.sub是個正則表達(dá)式方面的函數(shù),用來實現(xiàn)通過正則表達(dá)式,實現(xiàn)比普通字符串的replace更加強(qiáng)大的替換功能。這篇文章主要介紹了正則表達(dá)式re.sub替換不完整的問題及解決方案,需要的朋友可以參考下2018-08-08