У меня проблема с шаблоном регулярного выражения. В результате он возвращает два массива … Вот мой код:
$code = preg_match_all("/\< style\>(.*?)\<\/style\>/",$code,$matches); var_dump($matches);
В качестве теста я установил:
$code = ">< xxxxx> try blah fooo blah < /xxxxx> idfidf oh < x>< /x> < style> blah blah blah style1 < /style>< style>blah blah style 2 x< /style>
Он возвращает 2 массива, я имею в виду
$matches = array 0 => array 0 => string '< style> blah blah blah style1 < /style>' (length=38) 1 => string '< style>blah blah style 2 x< /style>' (length=34) 1 => array 0 => string ' blah blah blah style1 ' (length=23) 1 => string 'blah blah style 2 x' (length=19)
Матчи, которые я хочу, находятся во втором массиве. Я помещал пробел между тегами, потому что редактор не показывал HTML-теги.
Вы пробовали это:
echo $matches[0]; echo $matches[1]; // and so on, depend in the number of matches.
Следующий код работает для меня:
$code = "<xxxxx> try blah fooo blah </xxxxx> idfidf oh <x></x> <style> blah blah blah style1 </style><style>blah blah style 2 x</style>"; $code = preg_match_all("~<style>(.*?)</style>~si", $code, $matches); var_dump($matches[1]);
s
предназначен для DOT_ALL (включая новую строку) i
для соответствия аргументу игнорирования array(2) { [0]=> string(23) " blah blah blah style1 " [1]=> string(19) "blah blah style 2 x" }
Однако просто чтобы вы знали, что синтаксический анализ HTML из регулярного выражения – не очень хорошая идея, вам лучше использовать множество парсеров HTML, доступных для php.
Как насчет использования Xpath? http://nl.php.net/manual/en/class.domxpath.php
Работает для меня (большую часть времени, то есть;))