Ⅰ php preg_match()問題
php中preg_match() 函數用於進行正則表達式匹配,成功返回 1 ,否則返回 0
Ⅱ PHP函數preg_match_all正則表達式的基本使用詳細解析
了解正則表達式之前,須要掌握一些常用的正則表達式的基礎知識,這些如果能記得最好記得,記不住須要用的時候能查到就行,就多個特殊字元,所以說正則表達式玩的就是特殊,具體大家可以查看更加細致的說明。
preg_match_all函數具體說明大家可以查看PHP手冊,本文運用
preg_match_all用於測試正則表達的效果。
實例代碼:
復制代碼
代碼如下:
$html
=
'<div
id="biuuu">jb51.net</div><div
id="biuuu_2">jb51.net2</div><div
id="biuuu_3">jb51.net3</div>';
實例要求:分別將每一個DIV元素的ID和內容取出,如biuuu,biuuu_2,biuuu_3,jb51.net,jb51.net2和jb51.net3(一些常用的抓站要領就是這樣匹配的)
分析:字元串是一個基本的HTML元素,每一個DIV元素對應該一個ID和內容,並且是獨立的,首先考慮如何
取出一個DIV內的ID值和內容,如:jb51.net,然後匹配其它類似的元素。一個DIV中須要取出兩個值,也就是兩個匹配的表達式,第一個表達式用於匹配ID值(biuuu),第二個表達式用於匹配ID的內容(jb51.net),正則表達式常用的表達式運用小括弧,那麼前面的元素將會變成如下形式:
<div
id="(biuuu)">(jb51.net)</div>
<div
id="(表達式1)">(表達式2)</div>
好,運用如上小括弧把須要匹配的區域執行
了劃分,接下來就是如何
匹配各個表達式內的內容,我們猜想一個ID可能是字母,數字或下劃線,那這就變得基本了,運用中括弧就可以實現,如下:
表達式1:[a-zA-Z0-9_]+
(表示匹配大小寫字母,數字和下劃線)
那如何
匹配表達式2,因為ID的內容可以是任意的字元,但是要留心,不能匹配<或>字元,因為如果匹配這兩個字元將會把後面運用的DIV都匹配出來,因此須要排除這兩個字元開始的元素,也就是不匹配以<或>字元,如下:
表達式2:[^<>]+
(表示不匹配<和>字元)
這樣,須要匹配的子表達式就實現了,但是還要須要匹配一個
的表達式,要領如下:
表達式:/
'\"(表達式1)\"'>(表達式2)<\/div>/
留心其中的雙引號"和/須要運用
\轉義字元轉義,然後把前面兩個表達式放進去,
如下:
'\"([a-z0-9_]+)\"'>/<div
id=\"([a-z0-9_]+)\">([^<>]+)<\/div>/
這樣就實現一個匹配每一個DIV元素ID值和內容的正則表達式,然後運用
preg_match_all函數測試如下:
復制代碼
代碼如下:
$html
=
'<div
id="biuuu">jb51.net</div><div
id="biuuu_2">jb51.net2</div><div
id="biuuu_3">jb51.net3</div>';
preg_match_all('/<div\sid=\"([a-z0-9_]+)\">([^<>]+)<\/div>/',$html,$result);
var_mp($result);
結果:
復制代碼
代碼如下:
array(3)
{
[0]=>
array(3)
{
[0]=>
string(30)
"<div
id="biuuu">jb51.net</div>"
[1]=>
string(33)
"<div
id="biuuu_2">jb51.net2</div>"
[2]=>
string(33)
"<div
id="biuuu_3">jb51.net3</div>"
}
[1]=>
array(3)
{
[0]=>
string(5)
"biuuu"
[1]=>
string(7)
"biuuu_2"
[2]=>
string(7)
"biuuu_3"
}
[2]=>
array(3)
{
[0]=>
string(8)
"jb51.net"
[1]=>
string(9)
"jb51.net2"
[2]=>
string(9)
"jb51.net3"
}
}
共有三個表達式,分別顯示每一個表達式匹配的值,並以數組的形式存儲,這樣就把每一個DIV元素的ID和內容取出。運用正則表達式最主要還是要知道須要什麼,然後跟椐須要執行
匹配,並且思路清晰,並適當的藉助preg_match_all函數執行
輸出調試,非常方便。
Ⅲ php preg_match正則表達式問題
if(preg_match("/$keyword/i",$text)){
你這句先改成:if (preg_match("/$keyword/i", $text)) {
去掉了邊界符,如果需要加邊界符的話在程序里做處理好了。
送一個函數給你做關鍵字輸入的預處理
functionpretrip($strWord){
$arrReplace=array(
'['=>'[',
']'=>']',
'('=>'(',
')'=>')',
'\'=>'\\',
'?'=>'?',
'.'=>'.',
'*'=>'*',
'+'=>'+',
'-'=>'-',
'{'=>'{',
'}'=>'}',
'|'=>'|',
'/'=>'/',
);
returnstrtr($strWord,$arrReplace);
}
執行代碼的時候就是這樣:
$keyword="public static void main(String[] args)";
$keyword = pretrip($keyword);
searchText($file, $keyword);
Ⅳ php正則preg_match和preg_match_all
先將該頁面讀入字元串:$str=file_get_contents("文件路徑");
拼正則:$reg="/<td align="center" width="12\%">
<a href="([^<>]*)"
target="\_bank" rel="nofollow">([^<>]*)</a>
</td>"/U;
匹配:preg_match_all($reg,$str,$arr);
$arr就是了
Ⅳ PHP正則匹配問題preg_match("/([a-zA-Z]+)/","tech/web",$dirinfo);
使用括弧會對匹配結果進行分組。在匹配結果中,鍵為0的表示整個正則匹配的內容,之後的是對應的括弧中匹配的東西。
另外,你這里使用的是preg_match,所以只會匹配一個結果,如果想匹配所有的話,就使用preg_match_all
為了應正上面的描述,你可以運行以下代碼試試:
$dirinfo = array();
preg_match_all("/([a-zA-Z]+)\d+/","tech01/web",$dirinfo);
print_r($dirinfo);
Ⅵ php 正則preg_match怎麼用php 正則匹配出來啊
preg_match_all (PHP 3 >= 3.0.9, PHP 4, PHP 5)preg_match_all -- 進行全局正則表達式匹配 說明int preg_match_all ( string pattern, string subject, array matches [, int flags] ) 在 subject 中搜索所有與 pattern 給出的正則表達式匹...
Ⅶ php 正則表達式 preg_match 如何寫
根據規范限制位數 以及限制是否輸入的是 0905或者95或者8開始
preg_match('/(0905[0-9]{5}|95[0-9]{7}|8[0-9]{4})/isU',$string,$arr);
我這里有三種會員卡規范 以及規律
例如:
09051XXXX 一共9位 0開始或 0905開始
且
951XXXX 一共7位 9開始或 95開始
且
8XXXX 一共5位 8開始
if(preg_match('/(0[0-9]{8}|0905[0-9]{5})/is',$string,$arr))
{}
elseif(preg_match('/(95[0-9]{7}|9[0-9]{8})/is',$string,$arr))
{}
elseif(preg_match('/8[0-9]{4}/is',$string,$arr))
{}
Ⅷ php preg_match 正則
preg_match(第1個參數是你的正則表達式,第2個參數為你需要匹配的原字元串,第3個可有可無【一般用於稍微復雜的環境,是個數組,該數組就是你假如匹配了很多的情況下使用】)
$preg = "正則表達";
$str="<table ......................>.........</table>"
preg_match($preg,$str,$arr);
$arr是你的結果。