使用正则表达式获取php标记之间的代码
我试图从HTML模板文件中获取php代码,以执行它并将结果放回原处。 我可以使用什么正则表达式代码?是否有一种方法也可以返回找到的第一个标记的位置使用正则表达式获取php标记之间的代码,php,regex,Php,Regex,我试图从HTML模板文件中获取php代码,以执行它并将结果放回原处。 我可以使用什么正则表达式代码?是否有一种方法也可以返回找到的第一个标记的位置 <p>some html</p> <?php $some = "php code"; ?> <p>some <em>more</em> html</p> <?php $some = "more php code"; ?> 一些html 更多的htm
<p>some html</p>
<?php $some = "php code"; ?>
<p>some <em>more</em> html</p>
<?php $some = "more php code"; ?>
一些html
更多的html
我希望从html中过滤php代码。而不是“取出php并将其放回”,您应该将变量传递到模板文件
类似这样的内容:
<?php
function loadTemplate($path,$data=array()){
if (file_exists($path) === false){
throw new Exception('Template not found:'.$path);
return false;
}
extract($data);
ob_start();
require($path);
$return = ob_get_contents();
ob_end_clean();
return $return;
}
$vars = array('var1'=>$value,
'var2'=>$somevalue,
'var3'=>$someothervalue,
'var4'=>$blab);
$template = loadTemplate('path/to/thefile.php',$vars);
?>
然后从file.php中访问$vars
数组值,如
echo$var1
echo$var2
ect
希望它有助于preg_match(“//m”,$output,$matches)
preg_match("/<\?.*?\?>/m",$output,$matches)
或
preg_match(“//s”,$output,$matches)
应匹配所有行。HTML不是一种常规语言,因此您需要使用比正则表达式更强大的HTML解析器。我会寻找“”如果您包含一些示例代码,则更容易提供一个好的答案。请给我们一个模板文件的示例,并告诉我们您正在使用什么语言尝试解析它。这是因为您使用
作为分隔符。您需要进行preg_匹配(“/”,$output,$matches)
并使用/
作为分隔符。您需要设置多行标志。使用此preg\u match(//m',$output,$matches)
或preg\u match(//s',$output,$matches)
谢谢。我想使用ob_start()
是一个坏习惯吗?如果你看看大多数MVC框架或模板类的工作情况,它们都使用相同的方法。即使是codeigniter在其主要\u ci\u load()
方法中也是如此。谢谢,这是一个有趣的方法,我将深入探讨。这不是我问题的答案,而是一种更好的方法,适合我的情况。非常感谢你!如果字符串或注释中有“?>”则不起作用,例如:
preg_match("/<\?.*?\?>/s",$output,$matches)