我正在尝试解析youtube播放列表字段.
URL为:http://gdata.youtube.com/feeds/api/playlists/664AA68C6E6BA19B?v=2
$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/"AkYGSXc9cSp7ImA9Wx9VGEk.""> <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文档中的命名空间项目.
原文地址:https://www.jb51.cc/php/130480.html
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。