Java - NodeList无法获取Childnode

时间:2013-11-08 15:57:01

标签: java xml dom nodelist

我不明白如何让子节点用java解析xml文件。例如,我有这段代码:

import java.io.File;
import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import org.w3c.dom.Document;
import org.w3c.dom.Element;
import org.w3c.dom.Node;
import org.w3c.dom.NodeList;

public class Parser {

    public static void main(String args[]) {

        try{
            File stocks = new File("Stocks.xml");
            DocumentBuilderFactory dbFactory = DocumentBuilderFactory.newInstance();
            DocumentBuilder dBuilder = dbFactory.newDocumentBuilder();
            Document doc = dBuilder.parse(stocks);
            doc.getDocumentElement().normalize();



            NodeList nodes = doc.getElementsByTagName("stock");
            Node nodez = nodes.item(1);
            String s = nodez.getFirstChild().getNodeName(); //outputs #text?
                        System.out.println(s);
                        //If I try this
                        String s = nodez.getNodeName(); //outputs 'stock'


        } catch (Exception e) {
            e.printStackTrace();
        }
    }



}

因此,如果我尝试输出当前节点名称,它输出正确,但如果我尝试输出下一个子节点名称,它只输出#text。 如何正确输出我想要的任何节点?我以为我可以将方法用作getFirstChildgetNextSibling,但似乎我做错了什么?

您可以使用以下链接找到xml文件:

http://javarevisited.blogspot.com/2011/12/parse-xml-file-in-java-example-tutorial.html

2 个答案:

答案 0 :(得分:3)

元素“stock”包含文本,该文本作为第一个子项返回。您可以使用下面的内容:

        System.out.println(((Element) nodez).getElementsByTagName("symbol").item(0).getNodeName());
        // get all nodes
        NodeList nl=((Element) nodez).getElementsByTagName("*");
        for (int i = 0; i < nl.getLength(); i++) {
            System.out.println(nl.item(i).getNodeName());
        }

答案 1 :(得分:0)

您需要检查实际节点的node type

#text也是一个节点!但您可能正在寻找类型Element

使用Document#getElementsByTagName从文档中获取节点列表并迭代它。检查每个节点的类型以确定您感兴趣的节点。