XML解析器——DOM4j

前端之家收集整理的这篇文章主要介绍了XML解析器——DOM4j前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

4DOM4Jhttp://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,特别值得一提的是连SunJAXM也在用DOM4J.



  1. package com.lr.utils;
  2.  
  3. import java.io.File;
  4. import java.io.IOException;
  5. import java.util.ArrayList;
  6. import java.util.Iterator;
  7. import java.util.List;
  8.  
  9. import javax.xml.parsers.DocumentBuilderFactory;
  10. import javax.xml.parsers.ParserConfigurationException;
  11.  
  12. import org.dom4j.Attribute;
  13. import org.dom4j.Element;
  14. import org.dom4j.io.DOMReader;
  15. import org.dom4j.Document;
  16. import org.xml.sax.SAXException;
  17.  
  18. import com.lr.bean.BookInfo;
  19.  
  20. public class Dom4j {
  21. //公有的获取 所有书本信息的方法
  22. @SuppressWarnings("unchecked")
  23. public List<BookInfo> getInfo(){
  24. List<BookInfo> list=new ArrayList<BookInfo>();
  25. try {
  26. //DOM解析
  27. DOMReader reader=new DOMReader();
  28. DocumentBuilderFactory factory=DocumentBuilderFactory.newInstance();
  29. //通过文档构建器 创建一个 document 树
  30. Document doc=reader.read(factory.newDocumentBuilder().parse(new File("books.xml")));
  31. Element rootElement=doc.getRootElement();//获取根元素
  32. //迭代取值
  33. Iterator it=rootElement.elementIterator();
  34. Object ele;
  35. BookInfo bk=null;
  36. Element e;
  37. Attribute attr;
  38. while(it.hasNext()){ //含有子节点
  39. ele=it.next();
  40. if("book".equals(((Element) ele).getName())){ //元素名等于book
  41. bk=new BookInfo();
  42. //获取书本的所有属性
  43. for(Iterator attrList=((org.dom4j.Element) ele).attributeIterator();attrList.hasNext();){
  44. attr=(Attribute) attrList.next();
  45. if("id".equals(attr.getName())){
  46. bk.setId(attr.getValue());
  47. }
  48. }
  49. //获取书本的所有子节点
  50. for(Iterator el=((org.dom4j.Element) ele).elementIterator();el.hasNext();){
  51. e=(Element) el.next();
  52. if("bookName".equals(e.getName())){
  53. bk.setBookName(((org.dom4j.Element) e).getTextTrim());
  54. }else if("price".equals(e.getName())){
  55. bk.setPrice(((org.dom4j.Element) e).getTextTrim());
  56. }else if("bookPub".equals(e.getName())){
  57. bk.setBookPub(((org.dom4j.Element) e).getTextTrim());
  58. }
  59. }
  60. }
  61. list.add(bk);
  62. }
  63. } catch (SAXException e) {
  64. e.printStackTrace();
  65. } catch (IOException e) {
  66. e.printStackTrace();
  67. } catch (ParserConfigurationException e) {
  68. e.printStackTrace();
  69. }
  70. return list;
  71. }
  72. public static void main(String[] args){
  73. Dom4j d=new Dom4j();
  74. System.out.println(d.getInfo());
  75. }
  76. }

猜你在找的XML相关文章