Сопоставить весь текст между двумя тегами HTML, используя регулярное выражение в PHP - PullRequest
0 голосов
/ 19 мая 2011

У меня проблема с шаблоном регулярных выражений.В результате он возвращает два массива ... Вот мой код:

$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.

Ответы [ 3 ]

1 голос
/ 19 мая 2011

У меня работает следующий код:

$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 предназначен для игнорирования совпадения регистра

OUTPUT

array(2) {
  [0]=>
  string(23) " blah blah blah style1 "
  [1]=>
  string(19) "blah blah style 2 x"
}

Однако, просто для того, чтобы вы знали, что разбор HTML из регулярных выражений не очень хорошая идея, вам лучше использовать множество HTML-анализаторов, доступных для php.

1 голос
/ 19 мая 2011

Вы пробовали это:

echo $matches[0];
echo $matches[1]; // and so on, depend in the number of matches.
0 голосов
/ 19 мая 2011

Как насчет использования Xpath? http://nl.php.net/manual/en/class.domxpath.php

У меня работает (чаще всего;))

...