dsc80135 2016-01-05 19:48
浏览 217
已采纳

使用PHP Simple HTML DOM Parser从html中提取dom元素

I'm trying to extract links to the articles including the text, from this site using PHP Simple HTML DOM PARSER.

enter image description here

I want to extract all h2 tags for articles in the main page and I'm trying to do it this way:

    $html = file_get_html('http://www.winbeta.org');
    $articles = $html->getElementsByTagName('article');
    $a = null;

    foreach ($articles->find('h2') as $header) {
                $a[] = $header;
    }

    print_r($a);

according to the manual it should first get all the content inside article tags then for each article extract the h2 and save in array. but instead it gives me :

enter image description here

EDIT enter image description here

  • 写回答

1条回答 默认 最新

  • douzhi1924 2016-01-05 20:32
    关注

    There are several problems:

    • getElementsByTagName apparently returns a single node, not an array, so it would not work if you have more than one article tag on the page. Instead use find which does return an array;
    • But once you make that switch, you cannot use find on a result of find, so you should do that on each individual matched article tag, or better use a combined selector as argument to find;
    • Main issue: You must retrieve the text content of the node explicitly with ->plaintext, otherwise you get the object representation of the node, with all its attributes and internals;
    • Some of the text contains HTML entities like ’. These can be decoded with html_entity_decode.

    So this code should work:

    $a = array();
    foreach ($html->find('article h2') as $h2) { // any h2 within article
        $a[] = html_entity_decode($h2->plaintext);
    }
    

    Using array_map, you could also do it like this:

    $a = array_map(function ($h2) { return html_entity_decode($h2->plaintext); }, 
                   $html->find('article h2'));
    

    If you need to retrieve other tags within articles as well, to store their texts in different arrays, then you could do as follows:

    $a = array();
    $b = array();
    foreach ($html->find('article') as $article) {
        foreach ($article->find('h2') as $h2) {
            $a[] = html_entity_decode($h2->plaintext);
        }
        foreach ($article->find('h3') as $h3) {
            $b[] = html_entity_decode($h3->plaintext);
        }
    }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 metadata提取的PDF元数据,如何转换为一个Excel
  • ¥15 关于arduino编程toCharArray()函数的使用
  • ¥100 vc++混合CEF采用CLR方式编译报错
  • ¥15 coze 的插件输入飞书多维表格 app_token 后一直显示错误,如何解决?
  • ¥15 vite+vue3+plyr播放本地public文件夹下视频无法加载
  • ¥15 c#逐行读取txt文本,但是每一行里面数据之间空格数量不同
  • ¥50 如何openEuler 22.03上安装配置drbd
  • ¥20 ING91680C BLE5.3 芯片怎么实现串口收发数据
  • ¥15 无线连接树莓派,无法执行update,如何解决?(相关搜索:软件下载)
  • ¥15 Windows11, backspace, enter, space键失灵