当前位置: 网学 > 编程文档 > PHP > 正文

如何在PHP中使用正则表达式进行查找替换

来源:Http://myeducs.cn 联系QQ:点击这里给我发消息 作者: 用户投稿 来源: 网络 发布时间: 13/06/18
模式下工作并且后向引用后面紧跟着需要是另外一个数字(比如:在一个匹配模式后紧接着增加一个原文数字), 不能使用\\1这样的语法来描述后向引用。比如, \\11将会使 preg_replace()不能理解你希望的是一个\\1后向引用紧跟一个原文1,还是 一个\\11后向引用后面不跟任何东西。 这种情况下解决方案是使用${1}1。
这创建了一个独立的$1后向引用, 一个独立的原文1。 当使用e修饰符时, 这个函数会转义一些字符(即:''、"、 \ 和 NULL) 然后进行后向引用替换。当这些完成后请确保后向引用解析完后没有单引号或 双引号引起的语法错误(比如: ''strlen(\''$1\'')+strlen("$2")'')。确保符合PHP的 字符串语法,并且符合eval语法。因为在完成替换后,
引擎会将结果字符串作为php代码使用eval方式进行评估并将返回值作为最终参与替换的字符串。
subject:
要进行搜索和替换的字符串或字符串数组。 如果subject是一个数组,搜索和替换回在subject的每一个元素上进行, 并且返回值也会是一个数组。
limit:
每个模式在每个subject上进行替换的最大次数。默认是 -1(无限)。
count:
如果指定,将会被填充为完成的替换次数。
返回值:
如果subject是一个数组, preg_replace()返回一个数组, 其他情况下返回一个字符串。 如果匹配被查找到,替换后的subject被返回,其他情况下 返回没有改变的 subject。如果发生错误,返回 NULL 。
示例:
使用后向引用紧跟数值原文:
复制代码 代码如下:
<?php
$string = ''April 15, 2003'';
/*
*\w+字符重复一次或者多次
*\d+数字重复一次或者多次
*i忽略大小写
*/
$pattern = ''/(\w+) (\d+), (\d+)/i'';
/*
*$0 完整的模式匹配文本
*${1}1 第一个小括号中的模式匹配文本并且在后面加1
*\\3 第三个小括号中的模式匹配文本
*/
$replacement = ''$0:<br/> ${1}1,\\3'';
echo preg_replace($pattern, $replacement, $string);
?>

preg_replace()中使用基于索引的数组:
复制代码 代码如下:
$string = ''The quick brown fox jumped over the lazy dog.'';
$patterns = array();
$patterns[0] = ''/quick/'';
$patterns = ''/brown/'';
$patterns = ''/fox/'';
$replacements = array();
$replacements = ''bear'';
$replacements = ''black'';
$replacements[0] = ''slow'';
//会输出:The bear black slow jumped over the lazy dog.
echo preg_replace($patterns, $replacements, $string);
//对模式和替换内容按key进行排序我们可以得到期望的结果.
ksort($patterns);
ksort($replacements);
//会输出:The slow black bear jumped over the lazy dog.
echo preg_replace($patterns, $replacements, $string);

替换一些值:
复制代码 代码如下:
<?php
$patterns = array (''/(19|20)(\d{2})-(\d{1,2})-(\d{1,2})/'',
''/^\s*{(\w+)}\s*=/'');
$replace = array (''\3/\4/\1\2'', ''$\1 ='');
echo preg_replace($patterns, $replace, ''{startDate} = 1999-5-27'');
?>

使用修饰符''e'':
复制代码 代码如下:
<?php
$html_body = "<p><span>hello</span></p>";
//会输出:<P><SPAN>hello</SPAN></P>
echo htmlspecialchars(preg_replace("/(<\/?)(\w+)([^>]*>)/e",
"''\\1''.strtoupper(''\\2'').''\\3''",
$html_body));
?>

剥离空白字符:
复制代码 代码如下:
<?php
$str = ''foo o'';
$str = preg_replace(''/\s\s+/'', '' '', $str);
// 将会改变为''foo o''
echo $str;
?>

使用参数count:
复制代码 代码如下:
<?php
$count = 0;
echo preg_replace(array(''/\d/'', ''/\s/''), ''*'', ''xp 4 to'', -1 , $count);
//等价于echo

网学推荐

免费论文

原创论文

浏览:
设为首页 | 加入收藏 | 论文首页 | 论文专题 | 设计下载 | 网学软件 | 论文模板 | 论文资源 | 程序设计 | 关于网学 | 站内搜索 | 网学留言 | 友情链接 | 资料中心
版权所有 QQ:3710167 邮箱:3710167@qq.com 网学网 [Myeducs.cn] 您电脑的分辨率是 像素
Copyright 2008-2015 myeducs.Cn www.myeducs.Cn All Rights Reserved
湘ICP备09003080号