我尝试从文本中提取两个值之间的所有值,例如:<p> / <\/p>,现在我只能提取第一个值。
public function get_string_between($string, $start, $end)
{
$string = ' ' . $string;
$ini = strpos($string, $start);
if ($ini == 0) return '';
$ini += strlen($start);
$len = strpos($string, $end, $ini) - $ini;
return substr($string, $ini, $len);
}
$fullstring = '[{"content":{"content":"<h1>Acceptances<\/h1>","numbering":""},"children":[{"content":{"content":"<p><span>Ownership of the Products remains with the [X] and will not pass to the [Y] until one of the following events occurs:<\/span><\/p>","numbering":""},"children":[{"content":{"content":"<p><span>The [X] is paid for all of the Products and no other amounts are owed by the [Y] to the [X] in respect of other Products supplied by the [X].<\/span><\/p>","numbering":""},"children":[]},{"content":{"content":"<p><span>The [Y] sells the Products in accordance with this agreement in which case ownership of the Products will pass to the [Y] immediately before the Products are delivered to the [Y]'s customer.<\/span><\/p>","numbering":""},"children":[]}]},{"content":{"content":"<p><span>Where the Products are attached to or incorporated in other Products or are altered by the [Y], ownership of the Products shall not pass to the [Y] by virtue of the attachment, incorporation or alteration if the Products remain identifiable and, where attached to or incorporated in other Products, can be detached or removed from them.<\/span><\/p>","numbering":""}';
$paragraph_start_1 = '<p>';
$paragraph_end_2 = '<\/p>';
$paragraph = $this->get_string_between($fullstring, $paragraph_start_1, $paragraph_end_2);
//The output is just the first one and I need all.发布于 2020-03-24 17:25:09
改用正则表达式:
public function get_string_between($string, $start, $end)
{
$re = $start.'(.*?)'.$end.'/m';
preg_match_all($re, $string, $matches, PREG_SET_ORDER, 0);
return($matches);
}如果您想测试正则表达式:
$re = '/<p>(.*?)<\\\\\/p>/m';
$str = '<p>Lorem ipsum dolor sit amet, consectetur adipiscing elit. Aliquam pulvinar sollicitudin risus, et aliquam ante efficitur non. Pellentesque vel lorem euismod, efficitur turpis eu, vehicula tellus. Aliquam pretium nulla a ex sollicitudin fringilla. Praesent lacus nibh, consequat nec imperdiet nec, volutpat id lacus. Suspendisse tristique nisl sapien, imperdiet lobortis lectus vulputate dapibus. Curabitur vulputate enim felis. Curabitur vehicula risus et nisi vehicula luctus. Quisque id urna ut sem volutpat accumsan. Curabitur ut odio faucibus massa ultricies auctor. Curabitur id vulputate mi, dignissim varius turpis. In hac habitasse platea dictumst. Proin suscipit ex ut neque facilisis pellentesque. Ut et efficitur sapien.</p>
<p>Nulla facilisi. Phasellus maximus dui sed maximus sodales. Aliquam imperdiet est a elit sollicitudin, id lobortis lectus vehicula. Sed ut accumsan ligula. Maecenas id scelerisque risus, non pharetra nisi. Praesent rhoncus sem turpis, sed fermentum orci aliquet et. Sed vitae turpis id eros commodo maximus. Praesent fringilla eros nisl, ac cursus mauris iaculis vel. Donec vulputate ornare augue eget pulvinar.</p>';
preg_match_all($re, $str, $matches, PREG_SET_ORDER, 0);
// Print the entire match result
var_dump($matches);发布于 2020-03-24 17:31:30
只有当您绝对确定输入字符串始终遵循相同类型的格式时,才使用正则表达式作为此类问题的解决方案。例如:总是一个,但位置未知。
否则,请使用本机DOM或XML解析器提取文本。查看这个扩展的答案:How do you parse and process HTML/XML in PHP?
https://stackoverflow.com/questions/60827879
复制相似问题