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.

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

报告相同问题?

悬赏问题

  • ¥15 c语言怎么用printf(“\b \b”)与getch()实现黑框里写入与删除?
  • ¥20 怎么用dlib库的算法识别小麦病虫害
  • ¥15 华为ensp模拟器中S5700交换机在配置过程中老是反复重启
  • ¥15 java写代码遇到问题,求帮助
  • ¥15 uniapp uview http 如何实现统一的请求异常信息提示?
  • ¥15 有了解d3和topogram.js库的吗?有偿请教
  • ¥100 任意维数的K均值聚类
  • ¥15 stamps做sbas-insar,时序沉降图怎么画
  • ¥15 买了个传感器,根据商家发的代码和步骤使用但是代码报错了不会改,有没有人可以看看
  • ¥15 关于#Java#的问题,如何解决?