Java获取XML节点总结之读取XML文档节点的方法

时间:2021-07-30 15:40:20

dom4j是Java的XML API,用来读写XML文件的。目前有很多场景中使用dom4j来读写xml的。

要使用dom4j开发,需要下载导入dom4j相应的jar文件。

官网下载:http://www.dom4j.org/dom4j-1.6.1/

github下载:http://dom4j.github.io/

下载解压之后如图所示:

Java获取XML节点总结之读取XML文档节点的方法

我们只需要把dom4j-1.6.1.jar文件构建到我们开发项目中就可以了。

Java获取XML节点总结之读取XML文档节点的方法

下面就以Eclipse创建java项目的构建方法为例说明:

声明:本Java项目的开发环境JDK1.8,Eclipse版本 Neon.1 Release (4.6.1)

首先创建一个demo项目:

Java获取XML节点总结之读取XML文档节点的方法

在demo项目中创建一个lib文件,把dom4j-1.6.1.jar文件拷贝到lib中,然后右键dom4j-1.6.1jar文件。如图所示:

Java获取XML节点总结之读取XML文档节点的方法

点击Add to Bulid Path即可构建到项目中去了。
导入成功如图所示:

Java获取XML节点总结之读取XML文档节点的方法

在项目开发的过程中可以参考docs文件夹的(帮助文档),找到index.html打开,点击Quick start可以通过帮助文档进行学习 dom4j进行xml的解析。
如图所示:

Java获取XML节点总结之读取XML文档节点的方法

下面我将以详细例子去介绍Java操作xml文件,文件名为exmple.java。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
package vastsum;
 
import java.io.File;
import java.util.Iterator;
import java.util.List;
 
import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.Element;
import org.dom4j.Node;
import org.dom4j.io.SAXReader;
 
/**
 * 读取下xml文档,获得document对象。
 * 本文为xml连载第一篇,以下代码可以直接运行,结尾附上源码下载地址。
 */
class exmple {
  public static void main(String[] args) throws DocumentException
  {
    SAXReader reader = new SAXReader();
    Document document = reader.read(new File("./src/contact.xml"));
    
    /**
     * 节点对象的操作方法
     */
    
    //获取文档根节点
    Element root = document.getRootElement();
    //输出根标签的名字
    System.out.println(root.getName());
    
    
    //获取根节点下面的所有子节点(不包过子节点的子节点)
    List<Element> list = root.elements() ;
    //遍历List的方法
    for (Element e:list){
      System.out.println(e.getName());
    }
    
    
    //获得指定节点下面的子节点
    Element contactElem = root.element("contact");//首先要知道自己要操作的节点。
    List<Element> contactList = contactElem.elements();
    for (Element e:contactList){
      System.out.println(e.getName());
    
    
    
    //调用下面获取子节点的递归函数。
    getChildNodes(root);
    
    
    //获得当前标签下指定名称的第一个子标签
    Element conElem = root.element("contact");
    System.out.println(conElem.getName());
    
    
    //获得更深层次的标签(一层一层的获取)
    Element nameElem = root.element("contact").element("name");
    System.out.println(nameElem.getName());
  }
  
  //递归查询节点函数,输出节点名称
  private static void getChildNodes(Element elem){
    System.out.println(elem.getName());
    Iterator<Node> it=  elem.nodeIterator();
    while (it.hasNext()){
      Node node = it.next();
      if (node instanceof Element){
        Element e1 = (Element)node;
        getChildNodes(e1);
        }
      
      }
    }
  
  
}

下面是对应的xml文件,文件名为contact.xml:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
<?xml version="1.0" encoding="utf-8"?>
<contactList>
  <contact id="001" class="style">
    <name>张三</name>
    <age>20</age>
    <phone>134222223333</phone>
    <email>zhangsan@qq.com</email>
    <qq>432221111</qq>
  </contact>
  <contact id="002">
    <name>李四</name>
    <age>20</age>
    <phone>134222225555</phone>
    <email>lisi@qq.com</email>
    <qq>432222222</qq>
  </contact>
  <contactTwo>
    <name>王五</name>
    <age>32</age>
    <phone>465431341</phone>
    <emali>af@qq.com</emali>
    <qq>46164694</qq>
  </contactTwo>
  <test>测试</test>
  <test>其他用途</test>
</contactList>

两个文件的目录如题所示:

Java获取XML节点总结之读取XML文档节点的方法

以上就是小编为大家带来的Java获取XML节点总结之读取XML文档节点的方法全部内容了,希望大家多多支持服务器之家~