您好,欢迎来到三六零分类信息网!老站,搜索引擎当天收录,欢迎发信息

dom4j创建和解析xml文档实例教程

2025/4/25 5:59:29发布23次查看
dom4j解析
   特征:
1、jdom的一种智能分支,它合并了许多超出基本xml文档表示的功能。
2、它使用接口和抽象基本类方法。
3、具有性能优异、灵活性好、功能强大和极端易用的特点。
4、是一个开放源码的文件
jar包:dom4j-1.6.1.jar
创建 book.xml:
 1 package com.example.xml.dom4j; 2  3 import java.io.filewriter; 4 import org.dom4j.document; 5 import org.dom4j.documenthelper; 6 import org.dom4j.element; 7 import org.dom4j.io.outputformat; 8 import org.dom4j.io.xmlwriter; 9 /**10  * dom4j创建xml文档示例11  *12  */13 public class dom4jtest4 {14     public static void main(string[] args) throws exception {15         // 第二种方式:创建文档并设置文档的根元素节点16         element root2 = documenthelper.createelement(bookstore);17         document document2 = documenthelper.createdocument(root2);18 19         // 添加一级子节点:add之后就返回这个元素20         element book1 = root2.addelement(book);21         book1.addattribute(id, 1);22         book1.addattribute(name, 第一本书);23         // 添加二级子节点24         book1.addelement(name).settext(遇见未知的自己);25         book1.addelement(author).settext(张德芬);26         book1.addelement(year).settext(2014);27         book1.addelement(price).settext(109);28         // 添加一级子节点29         element book2 = root2.addelement(book);30         book2.addattribute(id, 2);31         book2.addattribute(name, 第二本书);32         // 添加二级子节点33         book2.addelement(name).settext(双城记);34         book2.addelement(author).settext(狄更斯);35         book2.addelement(year).settext(2007);36         book2.addelement(price).settext(29);37         38         // 设置缩进为4个空格,并且另起一行为true39         outputformat format = new outputformat(    , true);40  41         // 另一种输出方式,记得要调用flush()方法,否则输出的文件中显示空白42         xmlwriter xmlwriter3 = new xmlwriter(new filewriter(book.xml),format);43         xmlwriter3.write(document2);44         xmlwriter3.flush();45         // close()方法也可以46 47     }48 }
运行结果:
解析 book.xml:
 1 package com.example.xml.dom4j; 2  3 import java.io.file; 4 import java.util.iterator; 5 import java.util.list; 6 import org.dom4j.attribute; 7 import org.dom4j.document; 8 import org.dom4j.documentexception; 9 import org.dom4j.element;10 import org.dom4j.io.saxreader;11 /**12  * dom4j解析xml文档示例13  *14  */15 public class dom4jtest3 {16     17     public static void main(string[] args) {18         // 解析books.xml文件19         // 创建saxreader的对象reader20         saxreader reader = new saxreader();21         try {22             // 通过reader对象的read方法加载books.xml文件,获取docuemnt对象。23             document document = reader.read(new file(book.xml));24             // 通过document对象获取根节点bookstore25             element bookstore = document.getrootelement();26             system.out.println(根节点名:+bookstore.getname());27             // 通过element对象的elementiterator方法获取迭代器28             iterator it = bookstore.elementiterator();29             // 遍历迭代器,获取根节点中的信息(书籍)30             while (it.hasnext()) {31                 system.out.println(=====开始遍历子节点=====);32                 element book = (element) it.next();33                 system.out.println(子节点名:+book.getname());34                 // 获取book的属性名以及 属性值35                 list<attribute> bookattrs = book.attributes();36                 for (attribute attr : bookattrs) {37                     system.out.println(属性名: + attr.getname() + --属性值:38                             + attr.getvalue());39                 }40                 iterator itt = book.elementiterator();41                 while (itt.hasnext()) {42                     element bookchild = (element) itt.next();43                     system.out.println(节点名: + bookchild.getname() + --节点值: + bookchild.getstringvalue());44                 }45                 system.out.println(=====结束遍历该节点=====);46             }47         } catch (documentexception e) {48             e.printstacktrace();49         }50     }51 52 }
运行结果:
以上就是dom4j创建和解析xml文档实例教程的详细内容。
该用户其它信息

VIP推荐

免费发布信息,免费发布B2B信息网站平台 - 三六零分类信息网 沪ICP备09012988号-2
企业名录 Product