尝试使用 PHP 从 html 页面中提取信息


Trying to extract infos from an html page with PHP

我想知道如何执行以下操作。我有一个包含这部分代码的 html 页面:

<div id="sportSelect" class="longSelect">
                <select name="ctl00$ContentPlaceViewResults$MedalistResultsSearchSmallBlock$ResultsSearchSmallBlock$SportsListing" id="ctl00_ContentPlaceViewResults_MedalistResultsSearchSmallBlock_ResultsSearchSmallBlock_SportsListing" class="dropdownfilter">
        <option value="">Choose Sport*</option>
        <option selected="selected" value="31766">Archery</option>
        <option value="32588">Athletics</option>
        <option value="31753">Badminton</option>
        <option value="126990">Baseball</option>
        <option value="31341">Basketball</option>
</div>

现在我实现了这段代码:

<html>
<body>
<?php
// Include the library
include('simple_html_dom.php');
$html=file_get_html('http://www.olympic.org/olympic-results/london-2012/archery');
foreach($html->find('div') as $element) {
    if ($element->id == 'sportSelect')
    {
        $v =  $element->find('option[selected]', 0)->value . '</br>'; 
    }
}
echo $v
?>
</body>
</html>

没关系,它有效,因为我得到值 31766(代码与射箭相对应)。实际上,我想在 v 变量而不是 31766 中获取"射箭"。

我从 http://simplehtmldom.sourceforge.net/manual.htm 中看到的是,您应该使用类似于$element->find('option[selected]', 0)->plaintext的东西来获取节点的文本内容而不是其值属性。

在发现新语言/库时,我能给你的最好的提示是阅读文档。