java - "getDocumentElement"和 "getFirstChild"不同

标签 java xml nodes document

我有以下 Document 对象 - Document myDoc

myDoc 通过...保存一个 XML 文件

myDoc = DocumentBuilderFactory.newInstance()
            .newDocumentBuilder().parse(file);

现在我想获取 XML 文件的根目录。有什么区别吗

Node firstChild = this.myDoc.getFirstChild() 

Node firstChild = (Node)myDoc.getDocumentElement()

在第一种方式中,firstChild 持有XML 文件的节点根,但它没有Node 的深度。然而,在第二种方式中,firstChild 将成为具有所有深度的根。

例如,我有以下 XML

<inventory>
    <book num="b1">
    </book>
    <book num="b2">
    </book>
    <book num="b3">
    </book>
</inventory>

file 保存它。

在第一种情况下,int count = firstChild.getChildNodes() 给出 count = 0

第二种情况将给出 count = 3

我说得对吗?

最佳答案

如果在文档根节点之前还有其他节点(例如注释节点),则使用 myDoc.getFirstChild() 获得的节点可能不是文档根。看下面的例子:

import org.w3c.dom.*;

public class ReadXML {

    public static void main(String args[]) throws Exception{     

        DocumentBuilderFactory docFactory = DocumentBuilderFactory.newInstance();
        DocumentBuilder docBuilder = docFactory.newDocumentBuilder();

        // Document elements
        Document doc = docBuilder.parse(new File(args[0]));

        Node firstChild = doc.getFirstChild();
        System.out.println(firstChild.getChildNodes().getLength());
        System.out.println(firstChild.getNodeType());
        System.out.println(firstChild.getNodeName());

        Node root = doc.getDocumentElement();
        System.out.println(root.getChildNodes().getLength());
        System.out.println(root.getNodeType());
        System.out.println(root.getNodeName());

    }
}

解析以下 XML 文件时:

<?xml version="1.0"?>
<!-- Edited by XMLSpy -->
<catalog>
   <product description="Cardigan Sweater" product_image="cardigan.jpg">
      <catalog_item gender="Men's">
         <item_number>QWZ5671</item_number>
         <price>39.95</price>
         <size description="Medium">
            <color_swatch image="red_cardigan.jpg">Red</color_swatch>
            <color_swatch image="burgundy_cardigan.jpg">Burgundy</color_swatch>
         </size>
         <size description="Large">
            <color_swatch image="red_cardigan.jpg">Red</color_swatch>
            <color_swatch image="burgundy_cardigan.jpg">Burgundy</color_swatch>
         </size>
      </catalog_item>    
   </product>
</catalog>

给出以下结果:

0
8
#comment
3
1
catalog

但是如果我删除评论,它会给出:

3
1
catalog
3
1
catalog

关于java - "getDocumentElement"和 "getFirstChild"不同,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10937872/

相关文章:

java - 如何通过代码设置按钮背景图片

java - 在预期的情况下处理 NumberFormatException 的正确方法是什么?

java - 在 pom.xml 中指定目标

javascript - 如何使我的 D3 可折叠图表可折叠?

c - 需要解释C编程中的结构

java - 在启动画面后调用 MainActivity

java - 是否可以从 HANA 数据库调用 Java 函数

java - 简单-XML : Overriding an element name at runtime

xml - 如何使用 xslt 2.0 检查所有具有当前节点 w:r/w:t 子代的后代::w:p?

java - 按名称字母顺序对链表进行排序