php – 帮助使用DOMDocument解析XML

我正在尝试解析youtube播放列表字段. URL为:http://gdata.youtube.com/feeds/api/playlists/664AA68C6E6BA19B?v=2 我需要:标题,视频ID和默认缩略图. 我可以很容易地获得标题,但是当涉及到嵌套元素时,我有点迷失 $data = new DOMDocument(); if($data-load(h

我正在尝试解析youtube播放列表字段.

URL为:http://gdata.youtube.com/feeds/api/playlists/664AA68C6E6BA19B?v=2

我需要:标题,视频ID和默认缩略图.

我可以很容易地获得标题,但是当涉及到嵌套元素时,我有点迷失

$data = new DOMDocument();
        if($data->load("http://gdata.youtube.com/feeds/api/playlists/664AA68C6E6BA19B?v=2"))
        {       
            foreach ($data->getElementsByTagName('entry') as $video)
            {
                $title = $video->getElementsByTagName('title')->item(0)->nodeValue;
                $id    = ??
                $thumb = ??                 
            }
        }

这是XML(我已经删除了与此示例无关的元素)

<entry gd:etag="W/&quot;AkYGSXc9cSp7ImA9Wx9VGEk.&quot;">    
    <title>A GoPro Weekend On The Ice</title>

    <media:group>
        <media:thumbnail url="http://i.ytimg.com/vi/yk6wkfVNFQE/default.jpg" height="90" width="120" time="00:02:07" yt:name="default" />          
        <yt:videoid>yk6wkfVNFQE</yt:videoid>
    </media:group>

</entry>

我需要来自thumbnail-default的“videoid”和“url”

谢谢!

与您已经使用的
getElementsByTagName()类似,要访问命名空间元素(可以通过namespace:element-name识别),您可以使用
getElementsByTagNameNS()方法.

文档(上面链接)应该为您提供如何使用它的技术内容,足以说它将类似于以下(也使用getAttribute()).

$yt    = 'http://gdata.youtube.com/schemas/2007';
$media = 'http://search.yahoo.com/mrss/';

// Inside your loop
$id    = $video->getElementsByTagNameNS($yt,'videoid')->item(0)->nodeValue;
$thumb = $video->getElementsByTagNameNS($media,'thumbnail')->item(0)->getAttribute('url');

希望这应该为您提供一个跳板来跳过访问XML文档中的命名空间项目.

作者: dawei

【声明】:永州站长网内容转载自互联网,其相关言论仅代表作者个人观点绝非权威,不代表本站立场。如您发现内容存在版权问题,请提交相关链接至邮箱:bqsm@foxmail.com,我们将及时予以处理。

为您推荐

联系我们

联系我们

0577-28828765

在线咨询: QQ交谈

邮箱: xwei067@foxmail.com

工作时间:周一至周五,9:00-17:30,节假日休息

返回顶部