2

それを学ぼうとしてxpath式をいじってみてください。コードスニペットを見つけて、少し調整しました。私がやろうとしているのは、ページ上のすべてのリンクを取得することです。

$baseurl = "http://www.example.com";
$html = file_get_contents($baseurl);

$dom = new DOMDocument();
@$dom->loadHTML($html);
$xpath = new DOMXPath($dom);


$ahrefs = $xpath->query('//a');

foreach ($ahrefs as $ahref) { 
    echo $ahref->childNodes->item(0)->nodeValue . "<br />";
}

しかし今、私はアンカーテキストをつかんでいます。その部分が欲しいですhref。多分両方。私は何が間違っているのですか?

4

3 に答える 3

4

hrefを取得するには、ノードの属性プロパティにアクセスする必要があります

echo $ahref->attributes->getNamedItem("href")->nodeValue . "<br />";
于 2012-08-02T18:54:39.990 に答える
4

使用

//a/@href

追加のコード(この式の評価を除く)は必要ありません。

于 2012-08-03T04:34:45.303 に答える
1
echo $ahref->getAttribute('href') . "<br />";
于 2012-08-02T18:57:40.903 に答える