找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 957|回复: 0
打印 上一主题 下一主题

php小经验:解析preg_match与preg_match_all 函数

[复制链接]

2536

主题

2536

帖子

7532

积分

论坛元老

Rank: 8Rank: 8

积分
7532
跳转到指定楼层
楼主
发表于 2018-2-14 08:16:09 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

            正则表达式在 PHP 中的应用
在 PHP 应用中,正则表达式主要用于:
•正则匹配:根据正则表达式匹配相应的内容
•正则替换:根据正则表达式匹配内容并替换
•正则分割:根据正则表达式分割字符串
在 PHP 中有两类正则表达式函数,一类是 Perl 兼容正则表达式函数,一类是 POSIX 扩展正则表达式函数。二者差别不大,而且推荐使用Perl 兼容正则表达式函数,因此下文都是以 Perl 兼容正则表达式函数为例子说明。
定界符
Perl 兼容模式的正则表达式函数,其正则表达式需要写在定界符中。任何不是字母、数字或反斜线()的字符都可以作为定界符,通常我们使用 / 作为定界符。具体使用见下面的例子。
提示
尽管正则表达式功能非常强大,但如果用普通字符串处理函数能完成的,就尽量不要用正则表达式函数,因为正则表达式效率会低得多。关于普通字符串处理函数。
preg_match()
preg_match() 函数用于进行正则表达式匹配,成功返回 1 ,否则返回 0 。
语法:
int preg_match( string pattern, string subject [, array matches ] )
参数说明:

[TR]
参数
说明[/TR]
[TR]
[TD]pattern[/TD]
[TD]正则表达式[/TD][/TR]
[TR]
[TD]subject[/TD]
[TD]需要匹配检索的对象[/TD][/TR]
[TR]
[TD]matches[/TD]
[TD]可选,存储匹配结果的数组, $matches[0] 将包含与整个模式匹配的文本,$matches[1] 将包含与第一个捕获的括号中的子模式所匹配的文本,以此类推[/TD][/TR]例子 1 :
[U]复制代码[/U] 代码如下:
浏览器输出:
[U]复制代码[/U] 代码如下:
A match was found: PHP
在该例子中,由于使用了 i 修正符,因此会不区分大小写去文本中匹配 php 。
提示
preg_match() 第一次匹配成功后就会停止匹配,如果要实现全部结果的匹配,即搜索到subject结尾处,则需使用 preg_match_all() 函数。
例子 2 ,从一个 URL 中取得主机域名 :
[U]复制代码[/U] 代码如下:
浏览器输出:
[U]复制代码[/U] 代码如下:
域名为:jb51.net
preg_match_all()
preg_match_all() 函数用于进行正则表达式全局匹配,成功返回整个模式匹配的次数(可能为零),如果出错返回 FALSE 。
语法:
int preg_match_all( string pattern, string subject, array matches [, int flags ] )
参数说明:

[TR]
参数
说明[/TR]
[TR]
[TD]pattern[/TD]
[TD]正则表达式[/TD][/TR]
[TR]
[TD]subject[/TD]
[TD]需要匹配检索的对象[/TD][/TR]
[TR]
[TD]matches[/TD]
[TD]存储匹配结果的数组[/TD][/TR]
[TR]
[TD]flags[/TD]
[TD]
可选,指定匹配结果放入 matches 中的顺序,可供选择的标记有:
[ol]
  • PREG_PATTERN_ORDER:默认,对结果排序使 $matches[0] 为全部模式匹配的数组,$matches[1] 为第一个括号中的子模式所匹配的字符串组成的数组,以此类推
  • PREG_SET_ORDER:对结果排序使 $matches[0] 为第一组匹配项的数组,$matches[1] 为第二组匹配项的数组,以此类推
  • PREG_OFFSET_CAPTURE:如果设定本标记,对每个出现的匹配结果也同时返回其附属的字符串偏移量[/ol][/TD][/TR]下面的例子演示了将文本中所有  标签内的关键字(php)显示为红色。
    [U]复制代码[/U] 代码如下:
    学习php是一件快乐的事。所有的phper需要共同努力!";
    $kw = "php";
    preg_match_all('/([sS]*?)/',$str,$mat);
    for($i=0;$i'.$kw.'', $mat[0][$i]);
        $str = str_replace($mat[1][$i], $mat[0][$i], $str);
    }
    echo $str;
    ?>
    正则匹配中文汉字
    正则匹配中文汉字根据页面编码不同而略有区别:
    •GBK/GB2312编码:[x80-xff>]+ 或 [xa1-xff]+
    •UTF-8编码:[x{4e00}-x{9fa5}]+/u
    例子:
    [U]复制代码[/U] 代码如下:
    输出:
    [U]复制代码[/U] 代码如下:
    Array
    (
        [0] => Array
            (
                [0] => 学习
                [1] => 是一件快乐的事。
            )
    )
                
                
    您可能感兴趣的文章:
  • PHP 正则表达式常用函数使用小结
  • PHP提取字符串中的图片地址[正则表达式]
  • PHP 正则表达式之正则处理函数小结(preg_match,preg_match_all,preg_replace,preg_split)
  • php中使用preg_match_all匹配文章中的图片
  • php正则表达式使用的详细介绍
  • PHP函数preg_match_all正则表达式的基本使用详细解析
  • PHP的preg_match匹配字符串长度问题解决方法
  • PHP中preg_match函数正则匹配的字符串长度问题
  • PHP preg match正则表达式函数的操作实例
  • php preg_match的匹配不同国家语言实例
  • PHP正则匹配操作简单示例【preg_match_all应用】
  • PHP preg_match实现正则表达式匹配功能【输出是否匹配及匹配值】
            
  • 分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
    收藏收藏
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    用户反馈
    客户端