PHP 正则表达式匹配函数 preg_match 与 preg_match_all

PHP 正则表达式匹配函数 preg_match 与 preg_match_all

preg_match()

preg_match() 函数用于进行正则表达式匹配,成功返回 1 ,否则返回 0 。

语法:

1
int preg_match( string pattern, string subject [, 
array 
matches ] )

参数说明:

参数 说明
pattern 正则表达式
subject 需要匹配检索的对象
matches 可选,存储匹配结果的数组, $matches[0] 将包含与整个模式匹配的文本,$matches[1] 将包含与第一个捕获的括号中的子模式所匹配的文本,以此类推

例子 1:

1
2
3
4
5
6
7
8
9
<?php
if 
(preg_match(
"/php/i"

"PHP is the web scripting language of choice."

$matches
))
{
    
print 
"A match was found:" 

$matches
[0];
}
else
{
    
print 
"A match was not found."
;
}

输出:

1
A match was found:PHP

在该例子中,由于使用了 i 修正符,因此会不区分大小写去文本中匹配 php 。

 

注意:

preg_match() 第一次匹配成功后就会停止匹配,如果要实现全部结果的匹配,即搜索到subject结尾处,则需使用 preg_match_all() 函数。

例子 2 ,从一个 URL 中取得主机域名 :

1
2
3
4
5
6
7
8
<?php
// 从 URL 中取得主机名
preg_match(
"/^(http:\/\/)?([^\/]+)/i"
,
"http://blog.snsgou.com/index.php"

$matches
);
$host 

$matches
[2];
 
// 从主机名中取得后面两段
preg_match(
"/[^\.\/]+\.[^\.\/]+$/"

$host

$matches
);
echo 
"域名为:{$matches[0]}"
;

输出:

1
域名为:snsgou.com

 

preg_match_all()

preg_match_all() 函数用于进行正则表达式全局匹配,成功返回整个模式匹配的次数(可能为零),如果出错返回 FALSE 。

语法:

1
int preg_match_all( string pattern, string subject, 
array 
matches [, int flags ] )

参数说明:

参数 说明
pattern 正则表达式
subject 需要匹配检索的对象
matches 存储匹配结果的数组
flags

可选,指定匹配结果放入 matches 中的顺序,可供选择的标记有:

  1. PREG_PATTERN_ORDER:默认,对结果排序使 $matches[0] 为全部模式匹配的数组,$matches[1] 为第一个括号中的子模式所匹配的字符串组成的数组,以此类推
  2. PREG_SET_ORDER:对结果排序使 $matches[0] 为第一组匹配项的数组,$matches[1] 为第二组匹配项的数组,以此类推
  3. PREG_OFFSET_CAPTURE:如果设定本标记,对每个出现的匹配结果也同时返回其附属的字符串偏移量

下面的例子演示了将文本中所有 <pre></pre> 标签内的关键字(php)显示为红色。

1
2
3
4
5
6
7
8
9
10
11
12
<?php
$str 

"<pre>学习php是一件快乐的事。</pre><pre>所有的phper需要共同努力!</pre>"
;
$kw 

"php"
;
preg_match_all(
'/<pre>([\s\S]*?)<\/pre>/'

$str

$mat
);
for 
(
$i 
= 0; 
$i 

count
(
$mat
[0]); 
$i
++)
{
    
$mat
[0][
$i
] = 
$mat
[1][
$i
];
    
$mat
[0][
$i
] = 
str_replace
(
$kw

'<span style="color:#ff0000">' 

$kw 

'</span>'

$mat
[0][
$i
]);
    
$str 

str_replace
(
$mat
[1][
$i
], 
$mat
[0][
$i
], 
$str
);
}
echo 
$str
;
?>

输出效果:

PHP 正则表达式匹配函数 preg_match 与 preg_match_all

简化一下:

1
2
3
4
5
<?php
$str 

"<pre>学习php是一件快乐的事。</pre><pre>所有的phper需要共同努力!</pre>"
;
preg_match_all(
'/<pre>([\s\S]*?)<\/pre>/'

$str

$matches
);
print_r(
$matches
);
?>

输出:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
Array
(
    
[0] => Array
        
(
            
[0] => <pre>学习php是一件快乐的事。</pre>
            
[1] => <pre>所有的phper需要共同努力!</pre>
        
)
 
    
[1] => Array
        
(
            
[0] => 学习php是一件快乐的事。
            
[1] => 所有的phper需要共同努力!
        
)
 
)

 

 

参考:

http://php.net/manual/zh/function.preg-match-all.php

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/113731.html原文链接:https://javaforall.net

(0)
上一篇 2021年10月12日 下午3:00
下一篇 2021年10月12日 下午3:00


相关推荐

  • 数据可视化工具d3与echarts的区别

    数据可视化工具d3与echarts的区别数据可视化工具d3与echarts的区别

    2022年4月23日
    270
  • Flink教程(5)-Flink常用API

    Flink教程(5)-Flink常用APIFlink 教程 FlinkAPI 讲解 Flink 是一个同时具备流数据处理和批数据处理的分布式计算框架 Flink 代码主要是由 Java 实现 部分代码由 Scala 实现 Flink 既可以处理有界的批量数据集 也可以处理无界的实时数据集 Flink 处理的主要场景是流式数据 Flink 称得上是一款真正的流 批统一的大数据计算框架

    2026年3月17日
    2
  • linux7 没有dpkg,Linux 系统操作 (7):dpkg 命令

    linux7 没有dpkg,Linux 系统操作 (7):dpkg 命令Linux系统操作(7):dpkg命令文章目录综述:安装命令:查看与搜索命令:删除命令:不太常用的命令:参考文献:综述:广义的Debian是指一个致力于创建自由操作系统的合作组织及其作品,由于Debian项目众多内核分支中以Linux宏内核为主,而且Debian开发者所创建的操作系统中绝大部分基础工具来自于GNU工程,因此”Debian”常指Debian…

    2022年5月21日
    155
  • 数据结构考研面试被问的问题_考研程序设计与数据结构

    数据结构考研面试被问的问题_考研程序设计与数据结构逻辑结构与物理结构的区别算法的特点常见的数据结构单链表结构和顺序存储结构的区别线性链表数组和链表的区别判断疫个链表是否有环,如何找到这个环单链表和双链表的区别头指针和头结点的区别简述KMP算法栈和队列的区别栈和队列的相同之处和不同之处两个栈实现队列,两个队列实现栈树和二叉树的相关概念二叉平衡树二叉搜索树红黑树图的相关概念邻接矩阵与邻接表的区别深度优先遍历与广度…

    2026年1月26日
    5
  • 纠结应该先学Python还是Java?看完就有数了

    纠结应该先学Python还是Java?看完就有数了准备学习编程前,你一定会打开电脑搜索一下“先学Python还是先学Java?”扑面而来的是海量回答。如果你问一名Java程序员,肯定会建议你先学Java,因为他们认为Python像个乳臭未干的黄毛小子。但如果你问Python程序员,可能会得到一个完全相反的答案,他们认为Java是刻板啰嗦的老大爷,而人生苦短,我用Python。但别担心,今天我们将会从语言特色学习曲线职业方向市场需求…

    2022年7月8日
    22
  • 从MergeSort看HBase–一

    从MergeSort看HBase–一最近在研究 HBase 发现很多归并排序的影子 很有意思的是这个在数据结构教材里一笔带过的算法却在分布式计算领域经常出现 再一次证明了我们的教材也许已经很落伍了 为什么会用到归并排序纳 我们知道分布式系统中排序是基础 数据很容易在单台机器 或者节点 模块 中做到有序 但分布式环境需要在整个集群中达到有序 因此自然牵涉到把多个有序列合并为一个有序列的过程 这个过程就是 mergesort 登场的时

    2026年3月17日
    2

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号