大括号标记内的preg_match字符串

  
本文介绍了大括号标记内的preg_match字符串的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我想在标记之间抓取一个字符串。我的标记将使用大括号。

{myTag}Here is the string{/myTag}

到目前为止,我发现#<s*?$tagname[^>]*>(.*?)</$tagname[^>]*>#s这个匹配带有尖括号的标签<>。我想不出如何让它看起来像花括号。

最终,我希望分析整个页面并获取所有匹配项,然后使用字符串构建数组。

代码如下:

function everything_in_tags($string, $tagname)
{
    $pattern = "#<s*?$tagname[^>]*>(.*?)</$tagname[^>]*>#s";
    preg_match($pattern, $string, $matches);
    return $matches[1];
}

$var = everything_in_tags($string, $tagname);

推荐答案

<>的所有匹配项替换为{},并将preg_match()更改为PREG_MATCH_ALL()`以捕获这些标记内文本的多次匹配项。

function everything_in_tags($string, $tagname)
{
    $pattern = "#{s*?$tagname[^}]*}(.*?){/$tagname[^}]*}#s";
    preg_match_all($pattern, $string, $matches);
    return $matches[1];
}


$string = '{myTag}Here is the string{/myTag} and {myTag}here is more{/myTag}';
$tagname = 'myTag';
$var = everything_in_tags($string, $tagname);

忘掉我提到的有关转义大括号的内容-我弄错了。

这篇关于大括号标记内的preg_match字符串的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!

相关文章