php的pregmatch
① 请问php里面preg_match与preg_match_all有什么区别
preg_match只匹配一次,preg_match_all是全文匹配,即所有跟表达式一致的都找出来。
举个例子:abc
1、取出符号里的字符。preg_match_all("/(\w)+/","abc",$abc);print_r($abc);
显示结果为
Array( [0] = Array ( [0] = a [1] = b [2] = c )
[1] = Array ( [0] = a [1] = b [2] = c )
)
2、preg_match("/(\w)+/","abc",$abc);print_r($abc);
显示结果
Array( [0] = a [1] = a)
这两个函数的区别就是:preg_match_all()搜索匹配全部情况;preg_match()搜索匹配到一个后终止。
preg_match() 返回 pattern 所匹配的次数。要么是 0 次(没有匹配)或 1 次,因为 preg_match() 在第一次匹配之后将停止搜索。preg_match_all() 则相反,会一直搜索到 subject 的结尾处。如果出错 preg_match() 返回 FALSE。
希望我的回答能给你带来帮助!
② php preg_match匹配标签
你要做的第一步,是确定源码是什么,而不是在dom里面看。你所发的图如果有js操作过,你再怎么改正则也匹配不出内容。
③ php preg_match .*什么意思
preg_match — 执行一个正则表达式匹配!常用规则如:int preg_match_all ( string pattern, string subject, array matches [, int flags] )~~preg_match_all ("|<[^>]+>(.*)]+>|U","example:
this is a test ",$out, PREG_SET_ORDER);
print $out[0][0].", ".$out[0][1]."n";
print $out[1][0].", ".$out[1][1]."n";
?>
本例将输出:
example: , example:
this is a test , this is a test
④ php中的preg_match()函数
preg_match('/\\.(gif|jpeg|png|bmp|doc|)$/i', $filename)匹配正则表达式正则表达式的意思是点开头,然后那些扩展名结尾/i意思是不区分大小写,那两个函数的 用法不同返回值不同 第二个是全局匹配 既搜索所有匹配内容并以数组的模式返回,,,,下面那个错误问题,,那就是楼主没有区分单引号和双引号之间的区别,双引号之间的变量,会被替换成变量的值,而单引号之间的变量会直接当成字符串处理,
⑤ PHP preg_match 函数怎么匹配中文
<?php
//示例代码:
$str='hello这里是phppreg_match正则匹配演示';
//UTF8编码:正则表达式匹配中文;
if(preg_match('/[x{4e00}-x{9fa5}]+/u',$str)){
echo'匹配成功,有中文字符串!';
}else{
echo'没有中文字符串。';
}
//GB2312,GBK编码:正则表达式匹配中文;
if(preg_match("/^[".chr(0xa1)."-".chr(0xff)."A-Za-z0-9_]+$/",$str)){
echo'匹配成功,有中文字符串!';
}else{
echo'没有中文字符串。';
}
?>
⑥ php preg_match()问题
php中preg_match() 函数用于进行正则表达式匹配,成功返回 1 ,否则返回 0
⑦ php : preg_match() 是什么
preg_match -- 进行正则表达式匹配。并且只匹配一次
preg_match() 返回 正刚或是字符 所匹配的次数。要么是 0 次(没有匹配)或 1 次,因为 preg_match() 在第一次匹配之后将停止搜索。如果出错 preg_match() 返回FALSE。
⑧ php preg_match求正则表达式
<?php
$str='a:2:{s:5:"begin";a:0:{}s:8:"b2508957";a:17:
{s:8:"oho_var1";s:6:"1";s:8:"oho_var2";s:6:"1";s:8:"oho_var3";s:3
:"213";s:8:"oho_var4";s:18:"150402198301220618";s:8:"oho_var5";s:5:"123
21";s:8:"oho_var6";s:6:"213213";s:8:"oho_var7";s:12:"1";s:8:"oho_var8";s:3:"123";s:8:"oho_var9";s:3:"123";s:9:"oho_var10";s
:3:"231";s:9:"oho_var11";s:12:"测试数据";s:9:"oho_var12";s:3:"231";s:9
:"oho_var13";s:3:"213";s:9:"oho_var14";s:3:"123";s:9:"oho_file1";s:46:"
website/103216/upload/470_24524_1527045148.pdf";s:9:"oho_file2";s:46:"w
ebsite/103216/upload/276_24524_1527045148.pdf";s:9:"oho_file3";s:46:"we
bsite/103216/upload/309_24524_1527045148.pdf";}}';
preg_match_all('~"(oho_var(d+)?)";.*?"(.*?)"~',$str,$m);
$result=[];
$range=range(8,14);
foreach($m[2]as$index=>$v){
if(in_array($v,$range)){
$result[$m[1][$index]]=$m[3][$index];
}
}
print_r($result);
⑨ php中的preg_match()函数
preg_match()函数用于正则表达式知识匹配,如果成功则返回1,否则返回0。
Preg_match()在成功匹配之后停止匹配,如果要实现所有结果的内部匹配,则使用preg_match_all()函数。
php函数取得字符串长度:
1.首先,创建一个新的PHP文件并将其命名为test.php。
⑩ 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函数执行
输出调试,非常方便。