注意: DOM4J使用是需要上传jar包的。
先写一个XML栗子:
<?xml version="1.0" encoding="UTF-8"?>
<books xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:noNamespaceSchemaLocation="{book.xsd}">
<book id="1001">
<name>从入门到放弃</name>
<auto>高人</auto>
<price>35.5</price>
</book>
<book id="1002">
<name>从删库到跑路</name>
<auto>高小人</auto>
<price>48.3</price>
</book>
<book id="1003">
<name>从java到光头</name>
<auto>高大人</auto>
<price>16.6</price>
</book>
</books>
1DOM4J 解析 XML 的步骤
1) 创建 SAXReader 对象
2) 调用 read 方法
3) 获取根元素
4) 通过迭代器遍历直接节点
package com.bjsxt.DOM4j;
import java.io.File;
import java.util.Iterator;
import org.dom4j.Attribute;
import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.Element;
import org.dom4j.io.SAXReader;
public class TestDOM4j {
public static void main(String[] args) throws DocumentException {
//1) 创建 SAXReader对象
SAXReader saxreader=new SAXReader();
//2) 调用 read 方法
Document doc = saxreader.read(new File("book.xml"));
//3) 获取根元素
Element root = doc.getRootElement();
//4) 通过迭代器遍历直接节点
for(Iterator<Element> iteBook=root.elementIterator();iteBook.hasNext();) {
Element bookEle = iteBook.next();
//得到book的属性
for(Iterator<Attribute> itAtt=bookEle.attributeIterator();itAtt.hasNext();) {
Attribute att = itAtt.next();
System.out.println(att.getName()+"\t"+att.getText());
}
}
System.out.println("\n--------------");
for(Iterator<Element> itebook=root.elementIterator();itebook.hasNext();) {
Element bookEle = itebook.next();
for(Iterator<Element> subookEle=bookEle.elementIterator();subookEle.hasNext();) {
//得到每一个子元素
Element subEle = subookEle.next();
System.out.println(subEle.getName()+"\t"+subEle.getText());
}
System.out.println("==============");
}
}
}
运行结果: