编程语言
首页 > 编程语言> > 当单词多次出现时,如何使用具有相同模式的PHP preg_replace?

当单词多次出现时,如何使用具有相同模式的PHP preg_replace?

作者:互联网

抱歉,我的问题措辞太可怕了,但我不知道如何将其声明为问题.对我来说,仅显示代码并进行解释就比较容易.

我正在尝试编写一个函数来允许单词标记.我们有称为词汇表的单词数据库.我想要大量文本,并在此处寻找[G]个/多个单词[/ G]的多个实例.然后,我想将其替换为< a href =“ viewglossary.php?word = {[G] [/ G]}之间的WORD / WORDs”> {[G] [/ G]}之间的WORD / WORDs}< / a>

这是我当前的功能:

function getGlossary($str)
{
    $patterns = array();
    $patterns[]='/\[G\](.*)\[\/G\]/';
    $replacements = array();
    $replacements[]='<a href="viewglossary.php?word=$1">$1</a>';
    return preg_replace($patterns, $replacements, $str);
}
echo getGlossary($txt);

如果我只做[G] [/ G]标签的单个实例,它就可以工作.

$txt='What you need to know about [G]beans[/G]';

这将输出

What you need to know about <a href="viewglossary.php?word=beans">beans</a>

但是这个

$txt='What you need to know about [G]beans[/G] and [G]corn[/G]';

将输出

What you need to know about <a href="viewglossary.php?word=beans[/G] and [G]corn">beans[/G] and [G]corn</a>

我确定我的模式有问题.任何帮助,将不胜感激.

解决方法:

您需要使您的点星星懒:.*?

>没有?为了检查.*,.*会吃掉所有字符,直到最后[/ G]
> *量词是贪婪的,因此.*首先将字符串中的所有字符匹配到最后.然后,它仅回溯到允许[/ G]匹配所需的程度(因此,它仅回溯到最后一个[/ G]).
>?使量词“惰性”,以便它们仅在正则表达式其余部分匹配时才需要匹配.因此,它最多只能匹配第一个[/ G].

像这样修改您的正则表达式:

$pattern = "~\[G\](.*?)\[/G\]~";

请注意,为了使正则表达式更易于阅读,我更改了分隔符并未转义正斜杠,因为除非分隔符为斜杠,否则无需转义斜杠.常见的定界符包括〜,%,@,#…但实际上波浪号是最漂亮的.

标签:preg-replace,php,regex
来源: https://codeday.me/bug/20191121/2052925.html