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
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文档节点的方法全部内容了,希望大家多多支持服务器之家~