Java dom4j创建解析xml文档过程解析
DOM4J解析
特征:
1、JDOM的一种智能分支,它合并了许多超出基本XML文档表示的功能。
2、它使用接口和抽象基本类方法。
3、具有性能优异、灵活性好、功能强大和极端易用的特点。
4、是一个开放源码的文件
jar包:dom4j-1.6.1.jar
创建 book.xml:
package com.example.xml.dom4j;import java.io.FileWriter;import org.dom4j.Document;import org.dom4j.DocumentHelper;import org.dom4j.Element;import org.dom4j.io.OutputFormat;import org.dom4j.io.XMLWriter;/** * dom4j创建xml文档示例 * */public class Dom4JTest4 { public static void main(String[] args) throws Exception { // 第二种方式:创建文档并设置文档的根元素节点 Element root2 = DocumentHelper.createElement('bookstore'); Document document2 = DocumentHelper.createDocument(root2); // 添加一级子节点:add之后就返回这个元素 Element book1 = root2.addElement('book'); book1.addAttribute('id', '1'); book1.addAttribute('name', '第一本书'); // 添加二级子节点 book1.addElement('name').setText('遇见未知的自己'); book1.addElement('author').setText('张德芬'); book1.addElement('year').setText('2014'); book1.addElement('price').setText('109'); // 添加一级子节点 Element book2 = root2.addElement('book'); book2.addAttribute('id', '2'); book2.addAttribute('name', '第二本书'); // 添加二级子节点 book2.addElement('name').setText('双城记'); book2.addElement('author').setText('狄更斯'); book2.addElement('year').setText('2007'); book2.addElement('price').setText('29'); // 设置缩进为4个空格,并且另起一行为true OutputFormat format = new OutputFormat(' ', true); // 另一种输出方式,记得要调用flush()方法,否则输出的文件中显示空白 XMLWriter xmlWriter3 = new XMLWriter(new FileWriter('book.xml'),format); xmlWriter3.write(document2); xmlWriter3.flush(); // close()方法也可以 }}
运行结果:
解析 book.xml:
package com.example.xml.dom4j;import java.io.File;import java.util.Iterator;import java.util.List;import org.dom4j.Attribute;import org.dom4j.Document;import org.dom4j.DocumentException;import org.dom4j.Element;import org.dom4j.io.SAXReader;/** * dom4j解析xml文档示例 * */public class Dom4JTest3 { public static void main(String[] args) { // 解析books.xml文件 // 创建SAXReader的对象reader SAXReader reader = new SAXReader(); try { // 通过reader对象的read方法加载books.xml文件,获取docuemnt对象。 Document document = reader.read(new File('book.xml')); // 通过document对象获取根节点bookstore Element bookStore = document.getRootElement(); System.out.println('根节点名:'+bookStore.getName()); // 通过element对象的elementIterator方法获取迭代器 Iterator it = bookStore.elementIterator(); // 遍历迭代器,获取根节点中的信息(书籍) while (it.hasNext()) {System.out.println('=====开始遍历子节点=====');Element book = (Element) it.next();System.out.println('子节点名:'+book.getName());// 获取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 (DocumentException e) { e.printStackTrace(); } }}
运行结果:
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持好吧啦网。
相关文章: