使用Dom4j步骤
- 去官网下载 zip 包。或者百度云:
链接:https://pan.baidu.com/s/1FEMTo3g0rnYvEci9a3T05A
提取码:c8dw
复制这段内容后打开百度网盘手机App,操作更方便哦 - 在IDEA模块中创建一个文件夹:lib
- 将dom4j-2.1.1.jar文件复制到 lib 文件夹
- 在jar文件上点右键,选择 Add as Library -> 点击OK
- 在类中导包使用
Contact.xml文件:
<?xml version="1.0" encoding="UTF-8"?>
<contactList>
<contact id="1">
<name>潘金莲</name>
<gender>女</gender>
<email>panpan@itcast.cn</email>
</contact>
<contact>
<name>武松</name>
<gender>男</gender>
<email>wusong@itcast.cn</email>
</contact>
<contact id="3">
<name>武大狼</name>
<gender>男</gender>
<email>wuda@itcast.cn</email>
</contact>
</contactList>
DOM解析xml原理:
就是将XML文件在内存中生成了一棵DOM 树,如果要解析XML文件,先要得到Document元素,属性和文本都是节点。
得到document步骤:
- 获取SAXReader对象
SAXReader reader = new SAXReader();
- 获取InputStream流对象:读取xml文件
InputStream in = Demo1Test.class.getResourceAsStream("/Contact.xml");
- 获取document对象
Document document = reader.read(in);
下面的代码有详细的注释
Demo1Test.java:
public class Demo1Test {
public static void main(String[] args) throws DocumentException {
// 获取SAXReader对象
SAXReader reader = new SAXReader();
// 获取document对象
Document document = reader.read(Demo1Test.class.getResourceAsStream("/Contact.xml"));
// 获取根元素
Element rootElement = document.getRootElement();
// 获取 contact 元素对象
Element contact = rootElement.element("contact");
// 获取id为1的属性
Attribute id = contact.attribute("id");
System.out.println("属性名:" + id.getName());
System.out.println("属性值:" + id.getValue());
// 获取contact元素的所有子元素
List<Element> list = contact.elements();
for (Element element : list) {
System.out.println("元素 = " + element.getName());
System.out.println("元素内容 = " + element.getText());
}
// 直接获取 contact 元素的属性值
String value = contact.attributeValue("id");
System.out.println("id的值:"+value);
// 获取根元素下所有子元素
List<Element> elements = rootElement.elements();
for (Element element : elements) {
System.out.println(element);
}
}
}
运行结果: