0

使用 preg_match_all() 或更好的函数获取标签之间的所有文本的后续问题?

给定以下 POST 数据:

2010-June-3
<remove>2010-June-3</remove>
2010-June-15
2010-June-16
2010-June-17
2010-June-3
2010-June-1

我只想删除 2010-June-3 的第一个实例,但以下代码会删除所有数据。

$i = 1;
$pattern = "/<remove>(.*?)<\/remove>/";
preg_match_all($pattern, $_POST['exclude'], $matches, PREG_SET_ORDER);
    if (!empty($matches)) { 
        foreach ($matches as $match) {
            // replace first instance of excluded data
            $_POST['exclude'] = str_replace($match[1], "", $_POST['exclude'], $i);  
        }
   }

echo "<br /><br />".$_POST['exclude'];

这呼应:

<remove></remove>
2010-June-15
2010-June-16
2010-June-17
2010-June-1

它应该回显:

<remove>2010-June-3</remove>
2010-June-15
2010-June-16
2010-June-17
2010-June-3
2010-June-1
4

1 回答 1

3

您需要改用preg_replace()

$_POST['exclude'] = preg_replace( '/' . preg_quote( $match[1], '/' ) . '/', "", $_POST['exclude'], 1, $i );

$_POST['exclude'] 之后的变量是一个limit变量,如您在上面的链接中所见。

在日期字段中不需要preg_quote()函数,但由于它是一个变量,因此可能需要包含特殊的正则表达式字符。

于 2010-06-17T18:09:30.723 回答