|
|
|
|
<td valign="top" class="view_td3">
текст текст текст.... <b>текст<br /> </b> текст текст тектс<div align="right">
<a href="reply.php" class="view_a1">Цитировать</a>
</div>
</td>
|
Это пример. Вся страничка состоит из такого... Мне нужно получить весь текст, между <td valign="top" class="view_td3"> и <div align="right">
Делаю так:
<?
$pattern='|<td valign="top" class="view_td3">(.*)<div align="right">|i';
$text=preg_match_all($pattern,$forum,$link);
print count($link[1]);
?>
|
Получаю ноль. Почему? | |
|
|
|
|
|
|
|
для: Shorr Kan
(06.08.2006 в 04:39)
| | Попробуйте пробелы заменить на [\s]+, так как русский пробел не соответствует зачастую английскому. | |
|
|
|
|
|
|
|
для: cheops
(06.08.2006 в 11:52)
| | Если я вас правильно понял:
$pattern='|<td valign="top"[\s]+class="view_td3">(.*)<div[\s]+align="right">|i';
|
?
Не работает. Вовсе.
p.s. Насколько я понимаю, он неверно определяет <div align="right"> . Потому как таких блоков текста - там десятки. А он выдрал с первого, до упора (до конца странички). Это в прошлом варианте. В варианте с [\s]+ - он совсем погрустнел... | |
|
|
|
|
|
|
|
для: Shorr Kan
(06.08.2006 в 15:02)
| | Тогда используйте ваш первый вариант, но добавьте модификаторы s и U, т.е.
<?
$pattern='|<td valign="top" class="view_td3">(.*)<div align="right">|isU';
$text=preg_match_all($pattern,$forum,$link);
print count($link[1]);
?>
|
| |
|
|
|
|
|
|
|
для: cheops
(06.08.2006 в 15:26)
| | О! Сработало. Что они делают? | |
|
|
|
|
|
|
|
для: Shorr Kan
(06.08.2006 в 15:41)
| | s - сообщает, что соответствие может располагаться на нескольких строках, по умолчанию, соответствие ищется только в пределах строки.
U - инвертирует "жадность" регулярных выражений. Дело в том, что регулярные выражения по умолчанию "жадные", т.е. ищут наиболее длинное соответствие, U - позволяет сделать их "не жадными", т.е. искать наиболее короткое соответствие. | |
|
|
|
|
|
|
|
для: cheops
(06.08.2006 в 16:07)
| | Спасибо. Получается, дело было в s. | |
|
|
|