PHP正则解析多重循环模板示例

yipeiwu_com5年前PHP代码库

本文实例讲述了PHP正则解析多重循环模板。分享给大家供大家参考,具体如下:

$str = "客户您好,为您推荐以下项目:(crm{项目2:项目名称} (crm{项目3:项目名称}crm)  crm)以及(crm{项目1:项目名称}crm)";
$start = '(crm'; //循环开始标记
$end  = 'crm)'; //循环结束标记   
//循环标记,需要转移的符号,前面需要加入转义符 '\'
$need_escape = array('^', '$', '(', ')', '.', '[', ']', '|', '*', '?', '+', '/', '{', '}');
foreach($need_escape as $val)
{
   if(strpos($start, $val) !== FALSE)//存在需要转义的符号
   { 
     $escape = '\\'.$val;
     $start = str_replace($val, $escape, $start);
   }
   if(strpos($end, $val) !== FALSE)//存在需要转义的符号
   { 
     $escape = '\\'.$val;
     $end = str_replace($val, $escape, $end);
   }
}
/*----------------------------------
* 正则解析出【没有子循环】的【循环】
* 【没有子循环】:不包含循环开始标记
* 【循环】:被循环标记包含(开始标记、结束标记)
* ---------------------------------*/
//$pattern = '/\(crm((?!\(crm).)+crm\)/U';
$pattern = '/'.$start.'((?!'.$start.').)+'.$end.'/U';
preg_match_all($pattern, $str, $matches);
echo "<pre>";
print_r($matches);
echo "</pre>";

运行结果:

Array
(
    [0] => Array
        (
            [0] => (crm{项目3:项目名称}crm)
            [1] => (crm{项目1:项目名称}crm)
        )
    [1] => Array
        (
            [0] => }
            [1] => }
        )
)

PS:这里再为大家提供2款非常方便的正则表达式工具供大家参考使用:

JavaScript正则表达式在线测试工具:
http://tools.jb51.net/regex/javascript

正则表达式在线生成工具:
http://tools.jb51.net/regex/create_reg

更多关于PHP相关内容感兴趣的读者可查看本站专题:《php正则表达式用法总结》、《php程序设计安全教程》、《php安全过滤技巧总结》、《PHP数组(Array)操作技巧大全》、《PHP基本语法入门教程》、《php字符串(string)用法总结》及《php+mysql数据库操作入门教程

希望本文所述对大家PHP程序设计有所帮助。

相关文章

浅谈PHP中foreach/in_array的使用

php在开发效率很高,这是无可厚非的,但是却是在牺牲执行效率的。php数组功能非常强大,但是也要多加考虑,多试几种情况情况,以防万一,这里,我就简单的说两个遇到的坑,以后如果有发现更多的...

php中在PDO中使用事务(Transaction)

并且在执行的过程中, 如果其中的某条执行失败, 可以回滚所有已更改的操作. 如果执行成功, 那么这一系列操作都会永久有效. 事务很好的解决了在操作数据库的时候不同步的问题. 同时, 通过...

PHP ADODB生成下拉列表框功能示例

PHP ADODB生成下拉列表框功能示例

本文实例讲述了PHP ADODB生成下拉列表框功能。分享给大家供大家参考,具体如下: 一、代码 adodb.inc.php可从官方网站http://adodb.sourceforge.n...

PHP通过session id 实现session共享和登录验证的代码

先说说,这个机制的用途吧,到现在为止战地知道这个机制有两个方面的用途: 首先,多服务器共享session问题,这个大家应该都能够理解的,当一个网站的用户量过大,就会使用服务器集群,例如专...

在普通HTTP上安全地传输密码

1。理论      在普通HTTP上,一般表单中的密码都是以明文方式传到服务器进行处理的。这无疑给了坏人以可乘之机!这里我们就说说怎么传...