duanliang1019 2015-11-12 18:41
浏览 25
已采纳

检索Blogger帖子网址

I'm trying to retrieve posts from a Blogger using PHP and XML:

$file="BLOG URL/atom.xml";
$xml = simplexml_load_file($file);

And making a simple loop:

foreach ($xml->entry as $foo) {
    echo '<h2>' . $foo->title . '</h2>';
    echo '<p>' . $foo->updated . '</p>';
    echo $foo->link;
}

The only problem is that link is not showed.

Inspecting the code, each post has more than one link node:

<link href="" rel="replies" title="Postar comentários" type="application/atom+xml"/>
<link href="" rel="replies" title="0 Comentários" type="text/html"/>
<link href="" rel="edit" type="application/atom+xml"/>
<link href="" rel="self" type="application/atom+xml"/>
<link href="" rel="alternate" title="" type="text/html"/>

Is possible to get a node by his type atributte?

  • 写回答

1条回答 默认 最新

  • douju4278 2015-11-12 18:55
    关注

    You can get this by looping through the links and selecting one. So change:

    foreach ($xml->entry as $foo) {
        echo '<h2>' . $foo->title . '</h2>';
        echo '<p>' . $foo->updated . '</p>';
        echo $foo->link;
    }
    

    To:

    foreach ( $xml->entry as $foo ) {
        echo '<h2>' . $foo->title . '</h2>';
        echo '<p>' . $foo->updated . '</p>';
        foreach ( $foo->link as $link ) {
            $type = (string) $link->attributes()->{'type'};
            if ( $type == 'text/html' ) {
                echo (string) $link->attributes()->{'title'};;
            }
        }
    }
    

    Where 'text/html' is the type you want to select.

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥20 求快手直播间榜单匿名采集ID用户名简单能学会的
  • ¥15 DS18B20内部ADC模数转换器
  • ¥15 做个有关计算的小程序
  • ¥15 MPI读取tif文件无法正常给各进程分配路径
  • ¥15 如何用MATLAB实现以下三个公式(有相互嵌套)
  • ¥30 关于#算法#的问题:运用EViews第九版本进行一系列计量经济学的时间数列数据回归分析预测问题 求各位帮我解答一下
  • ¥15 setInterval 页面闪烁,怎么解决
  • ¥15 如何让企业微信机器人实现消息汇总整合
  • ¥50 关于#ui#的问题:做yolov8的ui界面出现的问题
  • ¥15 如何用Python爬取各高校教师公开的教育和工作经历