DOM4J特征:
1、DOM4J是JDOM的一种智能分支,它合并了许多超出基本XML文 档表示的功能。
2、它使用接口和抽象基本类方法。
3、具有性能优异、灵活性好、功能强大和极端易用的特点。
4、是一个开放源码的文件
DOM4解析用到的包:
import org.dom4j.Attribute;
import org.dom4j.Document;
import org.dom4j.Element;
import org.dom4j.io.SAXReader;
例:
源码:
<?xml version="1.0" encoding="UTF-8"?>
<bookstore>
<book id="1" name='book1'>
<name>挪威的森林</name>
<author>村上春树</author>
<year>2019</year>
<price>89</price>
</book>
<book id="2" name='book2'>
<name>设计模式</name>
<year>2018</year>
<price>386</price>
<language>English</language>
</book>
</bookstore>
public static void main(String[] args) {
// 创建SAXReader的对象reader
SAXReader reader = new SAXReader();
try {
// 通过reader对象的read方法加载data.xml文件,获取docuemnt对象。
Document document = reader.read(new File("src/com/xml/data.xml"));
// 通过document对象获取根节点bookstore
Element bookStore = document.getRootElement();
// 通过element对象的elementIterator方法获取迭代器
Iterator it = bookStore.elementIterator();
// 遍历迭代器,获取根节点中的信息(书籍)
while (it.hasNext()) {
System.out.println("=====开始遍历某一本书=====");
Element book = (Element) it.next();
// 获取book的属性名以及 属性值
List<Attribute> bookAttrs = book.attributes();
for (Attribute attr : bookAttrs) {
System.out.println("属性名:" + attr.getName() + "--属性值:"+ attr.getValue());
}
Iterator itt = book.elementIterator();
while (itt.hasNext()) {
Element bookChild = (Element) itt.next();
System.out.println("节点名:" + bookChild.getName() + "--节点值:" + bookChild.getStringValue());
}
System.out.println("=====结束遍历某一本书=====");
}
} catch (Exception e) {
e.printStackTrace();
}
}