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> 
+3

关闭我的头顶,标题节点应该反过来有一个孩子 - 一个文本节点,而一个应该包含实际的文本。 –

+0

@ full.stack.ex这是你的好东西。创建一个答案,我会接受。 – conor

标题节点应该有一个孩子 - 文本节点,并且那个应该包含实际的文本。

此外,谨防碎裂的:有可能是几个相邻的文本节点都有,这里讨论:http://www.drillio.com/en/software-development/java/fragmented-xml-text-nodes/