java与xml之DOM4J生成和解析XML文档

来源:互联网 发布:二代身份证相片 软件 编辑:程序博客网 时间:2024/04/30 23:19

虽然DOM4J代表了完全独立的开发结果,但最初,它是JDOM的一种智能分支。它合并了许多超出基本XML文档表示的功能,包括集成的XPath支持、
XML Schema支持以及用于大文档或流化文档的基于事件的处理。它还提供了构建文档表示的选项,它通过DOM4J
API和标准DOM接口具有并行访问功能。从2000下半年开始,它就一直处于开发之中。

   
为支持所有这些功能,DOM4J使用接口和抽象基本类方法。DOM4J大量使用了API中的Collections类,但是在许多情况下,它还提供一些替代方法以允许更好的性能或更直接的编码方法。直接好处是,虽然DOM4J付出了更复杂的API的代价,但是它提供了比JDOM大得多的灵活性。

    在添加灵活性、XPath集成和对大文档处理的目标时,DOM4J的目标与JDOM是一样的:针对Java开发者的易用性和直观操作。它还致力于成为比
JDOM更完整的解决方案,实现在本质上处理所有Java/XML问题的目标。在完成该目标时,它比JDOM更少强调防止不正确的应用程序行为。

    DOM4J是一个非常非常优秀的Java XML
API,具有性能优异、功能强大和极端易用使用的特点,同时它也是一个开放源代码的软件。如今你可以看到越来越多的Java软件都在使用DOM4J来读写
XML,特别值得一提的是连Sun的JAXM也在用DOM4J.

package com.mdy.xml.xmldemo;import java.io.FileInputStream;import java.io.FileNotFoundException;import java.io.FileOutputStream;import java.io.IOException;import java.io.UnsupportedEncodingException;import java.util.Iterator;import org.dom4j.Attribute;import org.dom4j.Document;import org.dom4j.DocumentException;import org.dom4j.DocumentHelper;import org.dom4j.Element;import org.dom4j.io.OutputFormat;import org.dom4j.io.SAXReader;import org.dom4j.io.XMLWriter;import com.mdy.xml.XMLDocument;public class Dom4JDemo implements XMLDocument {public static void main(String[] args) {String fileName = "dom4jdemo.xml";Dom4JDemo dom4jDemo = new Dom4JDemo();dom4jDemo.createXML(fileName);dom4jDemo.parserXML(fileName);}@Overridepublic void createXML(String fileName) {Document document = DocumentHelper.createDocument();Element books = document.addElement("books");// 循环创建三本书for(int i = 0;i<3;i++){Element book = books.addElement("book");book.addAttribute("id", (i+1)+"");Element bookName = book.addElement("name");bookName.setText("书本"+i);Element bookPrice = book.addElement("price");bookPrice.setText((i+1)*50+"");Element bookAuthor = book.addElement("author");bookAuthor.setText("作者"+i);}try {OutputFormat xmlFormat = new OutputFormat();  xmlFormat.setEncoding("UTF-8");//xmlFormat.setNewlines(true); // 设置换行//xmlFormat.setIndent(true);   // 设置缩进XMLWriter xmlWriter = new XMLWriter(new FileOutputStream(fileName),xmlFormat);xmlWriter.write(document);xmlWriter.close();} catch (UnsupportedEncodingException e) {e.printStackTrace();} catch (FileNotFoundException e) {e.printStackTrace();} catch (IOException e) {e.printStackTrace();}}@Overridepublic void parserXML(String fileName) {SAXReader reader = new SAXReader();try {Document document = reader.read(new FileInputStream(fileName));Element root = document.getRootElement();getNode(root);} catch (FileNotFoundException e) {e.printStackTrace();} catch (DocumentException e) {e.printStackTrace();}}public void getNode(Element node){if(node.getText() != null && !"".equals(node.getText().trim())){System.out.print("解析节点:"+node.getName());System.out.println("--->"+node.getText());}else{System.out.println("解析节点:"+node.getName());}Iterator attIterator = node.attributeIterator();while(attIterator.hasNext()){Attribute attribute = (Attribute)attIterator.next();System.out.println("属性:"+attribute.getName()+":"+attribute.getValue());}Iterator iterator = node.elementIterator();while (iterator.hasNext()) {getNode((Element) iterator.next());}}}

运行程序:

生成了dom4jdemo.xml文件:

<pre name="code" class="html"><?xml version="1.0" encoding="UTF-8"?><books>  <book id="1">    <name>书本0</name>    <price>50</price>    <author>作者0</author>  </book>  <book id="2">    <name>书本1</name>    <price>100</price>    <author>作者1</author>  </book>  <book id="3">    <name>书本2</name>    <price>150</price>    <author>作者2</author>  </book></books>


解析内容如下:

解析节点:books解析节点:book属性:id:1解析节点:name--->书本0解析节点:price--->50解析节点:author--->作者0解析节点:book属性:id:2解析节点:name--->书本1解析节点:price--->100解析节点:author--->作者1解析节点:book属性:id:3解析节点:name--->书本2解析节点:price--->150解析节点:author--->作者2


0 0
原创粉丝点击