|
|
|
| На странице из повторяющихся фрагментов вида <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>";
}
|
Не получается. Помогите разобраться. | |
|
|
|
|
|
|
|
для: 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>";
}
?>
|
| |
|
|
|
|
|
|
|
для: cheops
(26.10.2006 в 13:19)
| | Спасибо, cheops, все работает, и на локалке, и на удаленном сайте.
Можете подсказать, как найденные id сохранить в текстовом файле, так чтобы было по одному id на строку. Заранее, спасибо. | |
|
|
|
|
|
|
|
для: 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);
?>
|
| |
|
|
|
|
|
|
|
для: cheops
(26.10.2006 в 13:51)
| | Спасибо, cheops! | |
|
|
|