Форум: Форум PHPФорум ApacheФорум Регулярные ВыраженияФорум MySQLHTML+CSS+JavaScriptФорум FlashРазное
Новые темы: 0000000
MySQL 5. В подлиннике. Авторы: Кузнецов М.В., Симдянов И.В. Самоучитель MySQL 5. Авторы: Кузнецов М.В., Симдянов И.В. Социальная инженерия и социальные хакеры. Авторы: Кузнецов М.В., Симдянов И.В. PHP Puzzles. Авторы: Кузнецов М.В., Симдянов И.В. MySQL на примерах. Авторы: Кузнецов М.В., Симдянов И.В.
ВСЕ НАШИ КНИГИ
Консультационный центр SoftTime

Форум Регулярные Выражения

Выбрать другой форум

 

Здравствуйте, Посетитель!

вид форума:
Линейный форум Структурный форум

тема: Помогите разобраться с регулярным выражением
 
 автор: dmitrii_r   (26.10.2006 в 13:09)   письмо автору
 
 

На странице из повторяющихся фрагментов вида <a href="./news-item.php?id=571" class="news18">
надо извлечь все значения id. Вместо ./ может быть полный путь к файлу.

Делаю так:


$pattern = "#<a href=\"(?:.+)\/news-item\.php?id=(.+)\"\s+class=\"news18\">#siU";
preg_match_all($pattern, $contents, $out);
for ($i = 0; $i < count($out[1]); $i++)
        {
             $id = $out[1][$i];
             echo $id, "<br>";
        } 


Не получается. Помогите разобраться.

   
 
 автор: cheops   (26.10.2006 в 13:19)   письмо автору
 
   для: dmitrii_r   (26.10.2006 в 13:09)
 

Вопрос (?) тоже следует экранировать - это спецсимвол, попробуйте примерно следующий скрипт
<?php 
  $contents 
'На странице из повторяющихся фрагментов вида <a href="./news-item.php?id=571" class="news18"> 
надо извлечь все значения id. Вместо ./ может быть полный путь к файлу. 

Делаю так: '
;

$pattern "#news-item\.php\?id=([\d]+)\"[\s]+class#si"
preg_match_all($pattern$contents$out); 
for (
$i 0$i count($out[1]); $i++) 

  
$id $out[1][$i]; 
  echo 
$id"<br>"
}
?>

   
 
 автор: dmitrii_r   (26.10.2006 в 13:44)   письмо автору
 
   для: cheops   (26.10.2006 в 13:19)
 

Спасибо, cheops, все работает, и на локалке, и на удаленном сайте.
Можете подсказать, как найденные id сохранить в текстовом файле, так чтобы было по одному id на строку. Заранее, спасибо.

   
 
 автор: cheops   (26.10.2006 в 13:51)   письмо автору
 
   для: dmitrii_r   (26.10.2006 в 13:44)
 

Для этого можно воспользоваться скриптом
<?php  
  $contents 
'На странице из повторяющихся фрагментов вида <a href="./news-item.php?id=571" class="news18">  
надо извлечь все значения id. Вместо ./ может быть полный путь к файлу.  

Делаю так: '


$pattern "#news-item\.php\?id=([\d]+)\"[\s]+class#si";  
preg_match_all($pattern$contents$out);  
$fd fopen("text.txt","w");
fwrite($fd,implode("\r\n"$out[1]));
fclose($fd);
?>

   
 
 автор: dmitrii_r   (26.10.2006 в 14:01)   письмо автору
 
   для: cheops   (26.10.2006 в 13:51)
 

Спасибо, cheops!

   
Rambler's Top100
вверх

Rambler's Top100 Яндекс.Метрика Яндекс цитирования