4)DOM4Jhttp://dom4j.sourceforge.net
虽然DOM4J代表了完全独立的开发结果,但最初,它是JDOM的一种智能分支。它合并了许多超出基本XML文档表示的功能,包括集成的XPath支持、XMLSchema支持以及用于大文档或流化文档的基于事件的处理。它还提供了构建文档表示的选项,它通过DOM4JAPI和标准DOM接口具有并行访问功能。从2000下半年开始,它就一直处于开发之中。
为支持所有这些功能,DOM4J使用接口和抽象基本类方法。DOM4J大量使用了API中的Collections类,但是在许多情况下,它还提供一些替代方法以允许更好的性能或更直接的编码方法。直接好处是,虽然DOM4J付出了更复杂的API的代价,但是它提供了比JDOM大得多的灵活性。
在添加灵活性、XPath集成和对大文档处理的目标时,DOM4J的目标与JDOM是一样的:针对Java开发者的易用性和直观操作。它还致力于成为比JDOM更完整的解决方案,实现在本质上处理所有Java/XML问题的目标。在完成该目标时,它比JDOM更少强调防止不正确的应用程序行为。
DOM4J是一个非常非常优秀的JavaXMLAPI,具有性能优异、功能强大和极端易用使用的特点,同时它也是一个开放源代码的软件。如今你可以看到越来越多的Java软件都在使用DOM4J来读写XML,特别值得一提的是连Sun的JAXM也在用DOM4J.
package com.lr.utils; import java.io.File; import java.io.IOException; import java.util.ArrayList; import java.util.Iterator; import java.util.List; import javax.xml.parsers.DocumentBuilderFactory; import javax.xml.parsers.ParserConfigurationException; import org.dom4j.Attribute; import org.dom4j.Element; import org.dom4j.io.DOMReader; import org.dom4j.Document; import org.xml.sax.SAXException; import com.lr.bean.BookInfo; public class Dom4j { //公有的获取 所有书本信息的方法 @SuppressWarnings("unchecked") public List<BookInfo> getInfo(){ List<BookInfo> list=new ArrayList<BookInfo>(); try { //DOM解析 DOMReader reader=new DOMReader(); DocumentBuilderFactory factory=DocumentBuilderFactory.newInstance(); //通过文档构建器 创建一个 document 树 Document doc=reader.read(factory.newDocumentBuilder().parse(new File("books.xml"))); Element rootElement=doc.getRootElement();//获取根元素 //迭代取值 Iterator it=rootElement.elementIterator(); Object ele; BookInfo bk=null; Element e; Attribute attr; while(it.hasNext()){ //含有子节点 ele=it.next(); if("book".equals(((Element) ele).getName())){ //元素名等于book bk=new BookInfo(); //获取书本的所有属性 for(Iterator attrList=((org.dom4j.Element) ele).attributeIterator();attrList.hasNext();){ attr=(Attribute) attrList.next(); if("id".equals(attr.getName())){ bk.setId(attr.getValue()); } } //获取书本的所有子节点 for(Iterator el=((org.dom4j.Element) ele).elementIterator();el.hasNext();){ e=(Element) el.next(); if("bookName".equals(e.getName())){ bk.setBookName(((org.dom4j.Element) e).getTextTrim()); }else if("price".equals(e.getName())){ bk.setPrice(((org.dom4j.Element) e).getTextTrim()); }else if("bookPub".equals(e.getName())){ bk.setBookPub(((org.dom4j.Element) e).getTextTrim()); } } } list.add(bk); } } catch (SAXException e) { e.printStackTrace(); } catch (IOException e) { e.printStackTrace(); } catch (ParserConfigurationException e) { e.printStackTrace(); } return list; } public static void main(String[] args){ Dom4j d=new Dom4j(); System.out.println(d.getInfo()); } }
原文链接:https://www.f2er.com/xml/297332.html