Получение всех значений из тегов h1 с использованием php
Я хочу получить массив, содержащий все значения тега h1 из текста
Пример, если это где заданная строка ввода:
<h1>hello</h1>
<p>random text</p>
<h1>title number two!</h1>
Мне нужно получить массив, содержащий это:
titles[0] = 'hello',
titles[1] = 'title number two!'
Я уже понял, как получить первое значение h1 строки, но мне нужны все значения всех тегов h1 в данной строке.
В настоящее время я использую это для получения первого тега:
function getTextBetweenTags($string, $tagname)
{
$pattern = "/<$tagname ?.*>(.*)<\/$tagname>/";
preg_match($pattern, $string, $matches);
return $matches[1];
}
Я передаю ему строку, которую я хочу разобрать, и в качестве $тэга, который я ввел в "h1".
Я сам не писал сам, я пытался изменить код, чтобы делать то, что хочу, но ничего действительно не работает.
Я надеялся, что кто-то сможет мне помочь.
Спасибо заранее.
Ответы
Ответ 1
вы можете использовать simplehtmldom:
function getTextBetweenTags($string, $tagname) {
// Create DOM from string
$html = str_get_html($string);
$titles = array();
// Find all tags
foreach($html->find($tagname) as $element) {
$titles[] = $element->plaintext;
}
}
Ответ 2
function getTextBetweenTags($string, $tagname){
$d = new DOMDocument();
$d->loadHTML($string);
$return = array();
foreach($d->getElementsByTagName($tagname) as $item){
$return[] = $item->textContent;
}
return $return;
}
Ответ 3
Альтернатива DOM. Используйте, когда проблема с памятью.
$html = <<< HTML
<html>
<h1>hello<span>world</span></h1>
<p>random text</p>
<h1>title number two!</h1>
</html>
HTML;
$reader = new XMLReader;
$reader->xml($html);
while($reader->read() !== FALSE) {
if($reader->name === 'h1' && $reader->nodeType === XMLReader::ELEMENT) {
echo $reader->readString();
}
}
Ответ 4
function getTextBetweenH1($string)
{
$pattern = "/<h1>(.*?)<\/h1>/";
preg_match_all($pattern, $string, $matches);
return ($matches[1]);
}