一、导入jar包
Dom4J不是Java提供的解析xml的方法,所以需要导入额外的jar包。可以去官方网站下载。
二、Dom4J解析实例
books.xml
<?xml version="1.0" encoding="UTF-8"?>
<bookstore>
<book id="1">
<name>冰与火之歌</name>
<author>乔治马丁</author>
<time>2014</time>
<price>89</price>
</book>
<book id="2">
<name>安徒生童话</name>
<price>40</price>
<time>2004</time>
<language>English</language>
</book>
</bookstore>
Dom4JDemo.java
public class Dom4JDemo {
@SuppressWarnings("unchecked")
public static void main(String[] args) {
int index = 0;
//1、新建SAXReader对象
SAXReader reader = new SAXReader();
try {
//2、将xml文件加载进reader中
Document document = reader.read(new File("xml/books.xml"));
//3、获得根节点
Element root = document.getRootElement();
//4、获得根节点子节点的的迭代器
Iterator<Element> it = root.elementIterator();
//5、遍历所有的子节点
while(it.hasNext()) {
Element element = it.next();
index++;
System.out.println("======读取第" + index + "本书信息======");
//6-1、如果不知道属性有哪些,可以通过Element.attributes()方法获取所有属性,然后遍历节点的属性
List<Attribute> attrs = element.attributes();
for(Attribute attr : attrs) {
System.out.println("属性名:" + attr.getName() + "-->属性值:" + attr.getValue());
}
//6-2、如果已知节点的属性名,可以直接通过Element.attributeValue(String name)获取节点的属性
System.out.println("已知有id属性-->属性值:" + element.attributeValue("id"));
//7、获取子节点迭代器
Iterator<Element> itt = element.elementIterator();
//8、遍历所有子节点,获取子节点的值
while(itt.hasNext()) {
Element child = itt.next();
System.out.println("子节点:" + child.getName() + "-->节点值:" + child.getStringValue());
}
System.out.println("======读取第" + index + "本书信息结束======");
}
} catch (DocumentException e) {
e.printStackTrace();
}
}
}
运行结果:
======读取第1本书信息======
属性名:id-->属性值:1
已知有id属性-->属性值:1
子节点:name-->节点值:冰与火之歌
子节点:author-->节点值:乔治马丁
子节点:time-->节点值:2014
子节点:price-->节点值:89
======读取第1本书信息结束======
======读取第2本书信息======
属性名:id-->属性值:2
已知有id属性-->属性值:2
子节点:name-->节点值:安徒生童话
子节点:price-->节点值:40
子节点:time-->节点值:2004
子节点:language-->节点值:English
======读取第2本书信息结束======