Java获取XML节点总结之读取XML文档节点
dom4j是Java的XML API,用来读写XML文件的。目前有很多场景中使用dom4j来读写xml的。
要使用dom4j开发,需要下载导入dom4j相应的jar文件。
官网下载:http://www.dom4j.org/dom4j-1.6.1/
github下载:http://dom4j.github.io/
下载解压之后如图所示:

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

下面就以Eclipse创建java项目的构建方法为例说明:
声明:本Java项目的开发环境JDK1.8,Eclipse版本 Neon.1 Release (4.6.1)
首先创建一个demo项目:

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

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

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

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

相关推荐
与卿画眉共浮生 2020-10-14
xiyang 2020-08-21
XGQ 2020-07-04
Andrewjdw 2020-05-29
Yakamoz 2020-05-26
行吟阁 2020-05-18
88491874 2020-04-30
baijinswpu 2020-07-29
leonranri 2020-07-26
zhongliwen 2020-07-05
麋鹿麋鹿迷了路 2020-07-05
zengyu00 2020-07-05
CoderBoy 2020-06-28
whbing 2020-06-28
绝望的乐园 2020-06-27
wellfly 2020-06-26
菇星獨行 2020-06-25
草原孤狼 2020-06-25
坚持着执着 2020-06-16