Android解析XML以获取节点值
问题描述:
所以,我写了一些小的东西来解析Youtube用户的feed。Android解析XML以获取节点值
问题是,当我打电话给getNodeValue()
时返回null。为什么是这样?任何想法或替代方式接近表示赞赏,谢谢。
这里是如何我目前正在做的事情的一个片段:
try {
Document d = DocumentBuilderFactory.newInstance().newDocumentBuilder().parse("https://gdata.youtube.com/feeds/api/users/estudiosabiertostv/uploads");
NodeList entries = d.getElementsByTagName("entry");
for(int i = 0; i < entries.getLength(); i++) {
NodeList children = entries.item(i).getChildNodes();
YoutubeVideo video = new YoutubeVideo();
for(int j = 0; j < children.getLength(); j++) {
Node child = children.item(j);
if(child.getNodeName().equals("title")) {
video.title = child.getNodeValue();
break;
}
}
videos.add(video);
}
}
catch (Exception e) {
e.printStackTrace();
}
这里就是我从获得XML的网址:
https://gdata.youtube.com/feeds/api/users/estudiosabiertostv/uploads
下面是一个条目的片段,我试图获得标题
<entry>
<id>http://gdata.youtube.com/feeds/api/videos/oDbOmTY3gDw</id>
<published>2012-12-17T08:14:12.000Z</published>
<category scheme="http://schemas.google.com/g/2005#kind" term="http://gdata.youtube.com/schemas/2007#video"/>
<title type="text">SEAS - Grupo San Valero - Crea tu propia Navidad (2012)</title>
<content type="text">Felicitación de Navidad de SEAS, Estudios Abiertos del Grupo San Valero</content>
<link rel="alternate" type="text/html" href="http://www.youtube.com/watch?v=oDbOmTY3gDw&feature=youtube_gdata"/>
<author>
<name>estudiosabiertostv</name>
<uri>http://gdata.youtube.com/feeds/api/users/estudiosabiertostv</uri>
</author>
</entry>
答
标题节点应该有一个孩子 - 文本节点,并且那个应该包含实际的文本。
此外,谨防碎裂的:有可能是几个相邻的文本节点都有,这里讨论:http://www.drillio.com/en/software-development/java/fragmented-xml-text-nodes/
关闭我的头顶,标题节点应该反过来有一个孩子 - 一个文本节点,而一个应该包含实际的文本。 –
@ full.stack.ex这是你的好东西。创建一个答案,我会接受。 – conor