>  기사  >  백엔드 개발  >  PHP에서 정규식 검색을 수행하고 바꾸는 방법은 무엇입니까?

PHP에서 정규식 검색을 수행하고 바꾸는 방법은 무엇입니까?

WBOY
WBOY원래의
2021-11-01 14:06:332236검색

在之前的文章中给大家带来了《PHP中全局正则表达式匹配及匹配数组元素(实例详解)》,其中给大家介绍了PHP中怎样通过正则表达式来进行匹配相应的元素的相关知识,本篇文章我们来看一下应该怎样执行一个正则表达式的搜索和替换。希望对大家有帮助!

"PHP에서

在之前的文章中我们了解了怎样去执行正则表达式的匹配以及怎样去检测与给定模式的数组元素,这些通过 preg_match() 函数、preg_match_all()函数和preg_grep() 函数就能够实现。但是对于字符串的操作,这些函数就有些鞭长莫及了。

字符串的替换是字符串操作中非常重要的内容之一。对于一些比较复杂的字符串替换操作,这时候我们就需要通过正则表达式的替换函数 preg_replace() 来完成正则表达式的搜索和替换工作,接下来我们就来看一下preg_replace()函数的使用吧。

<strong><span style="font-size: 20px;">preg_replace()</span></strong>函数

PHP 中的 preg_replace() 函数可以执行正则表达式的搜索和替换,是一个强大的字符串替换处理函数,可以用来处理那些比较复杂的字符串替换操作,该函数的语法格式如下:

preg_replace($pattern, $replacement, $subject [, $limit = -1 [, &$count]])

其中参数需要注意的是:

  • $pattern表示要搜索的模式,可以使一个字符串或字符串数组;$replacement表示用于替换的字符串或字符串数组。

  • 其中如果这个参数是一个字符串,并且 $pattern 是一个数组,那么所有的模式都使用这个字符串进行替换。如果 $pattern$replacement 都是数组,每个 $pattern 使用 $replacement 中对应的元素进行替换。如果 $replacement 中的元素比 $pattern 中的少,多出来的 $pattern 使用空字符串进行替换。

  • $subject表示要进行搜索和替换的字符串或字符串数组,如果 $subject 是一个数组,搜索和替换回在 $subject 的每一个元素上进行, 并且返回值也会是一个数组。如果 $subject 是一个数组,preg_replace() 函数会返回一个数组,其他情况下返回一个字符串。

  • $limit是个可选参数,每个模式在每个 $subject 上进行替换的最大次数。默认是 -1$count是个可选参数,如果指定,将会被填充为完成的替换次数。

如果函数 preg_replace() 搜索到匹配项,则会返回被替换后的 $subject,否则返回没有改变的 $subject。preg_replace() 函数的每个参数(除了参数 $limit)都可以是一个数组。如果参数 $pattern 和参数 $replacement 都是数组,那么该函数将以其键名在数组中出现的顺序来进行处理。如果发生错误,则返回 NULL。

接下来我们通过一个简单的示例来看一下使用 preg_replace() 函数替换字符串,示例如下:

<?php
    $string = &#39;www.php.cn&#39;;
    $pattern = &#39;/(\w+).(\w+).(\w+)/i&#39;;
    $replacement = &#39;http://$1.$2.$3/&#39;;
    echo preg_replace($pattern, $replacement, $string);
?>

输出结果:

"PHP에서

通过上述示例,我们需要知道的是:

参数 $replacement 中可以包含后向引用 \\n $n,语法上首选后者。每个这样的引用将被匹配到的第 n 个捕获子组捕获到的文本替换。n 可以是 0-99,\\0$0 代表完整的模式匹配文本。

捕获子组的序号计数方式为:代表捕获子组的左括号从左到右,从 1 开始数。如果要在 $replacement 中使用反斜线,必须使用 4 个"\\\\" 因为这首先是 php 的字符串,经过转义后是两个,再经过正则表达式引擎后才被认为是一个原文反斜线。

当在替换模式下工作并且后向引用后面紧跟着需要是另外一个数字,比如:在一个匹配模式后紧接着增加一个原文数字,不能使用 \\1 这样的语法来描述后向引用。

比如,\\11 将会使 preg_replace() 不能理解你希望的是一个 \\1 后向引用紧跟一个原文 1,还是一个 \\11 后向引用后面不跟任何东西。这种情况下解决方案是使用 ${1}1。这创建了一个独立的 $1 后向引用,一个独立的原文 1

当使用被弃用的 e 修饰符时,这个函数会转义一些字符即:'"\NULL,然后进行后向引用替换。当这些完成后请确保后向引用解析完后没有单引号或双引号引起的语法错误,比如:'strlen(\'$1\')+strlen("$2")'。确保符合 PHP 的字符串语法,并且符合 eval 语法。因为在完成替换后,引擎会将结果字符串作为 php 代码使用 eval 方式进行评估并将返回值作为最终参与替换的字符串。

preg_filter() 函数

上文中介绍了preg_replace() 函数,是用来执行一个正则表达式的搜索和替换的,PHP preg_filter() 函数也用于执行一个正则表达式的搜索和替换,作用与preg_replace() 函数相同,不同的是 preg_filter() 函数只返回匹配成功的结果,而 preg_replace() 返回所有结果,不管是否匹配成功。

即使如此,我们也应该了解一下preg_filter() 函数的用法,关于 preg_filter() 的工作原理和参数说明可以参考 preg_replace() 函数。

接下来我们直接通过示例来看一下preg_filter() 函数的使用,示例如下:

<?php
    echo "<pre class="brush:php;toolbar:false">";
    $arr1 = array(
        &#39;http://aaa.bbbbb.com/php/&#39;,
        &#39;http://aaa.bbbbb.com/java/&#39;,
        &#39;http://aaa.bbbbb.com/python/&#39;,
        &#39;http://www.google.com/cn/&#39;,
        &#39;http://cn.asdaf.com/&#39;,
    );
    $pattern = array(&#39;/aaa\./&#39;,&#39;/bbbbb/&#39;);
    $replacement = array(&#39;www.&#39;,&#39;baidu&#39;);
    print_r( preg_replace($pattern, $replacement, $arr1) );
    print_r( preg_filter($pattern, $replacement, $arr1) );
?>

输出结果:

"PHP에서

有上述示例能够看出,虽然同样是执行一个正则表达式的搜索和替换,preg_filter() 函数只返回匹配成功的结果,而 preg_replace() 返回所有结果,不管是否匹配成功。这就是preg_filter() 函数和preg_replace()函数的区别。

大家如果感兴趣的话,可以点击《PHP视频教程》、《正则表达式手册》进行更多关于PHP和正则表达式知识的学习。

위 내용은 PHP에서 정규식 검색을 수행하고 바꾸는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.