码迷,mamicode.com
首页 > 其他好文 > 详细

XML解析器——DOM4j

时间:2015-01-21 18:24:48      阅读:171      评论:0      收藏:0      [点我收藏+]

标签:xml解析

  4DOM4J http://dom4j.sourceforge.net 

    虽然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,特别值得一提的是连SunJAXM也在用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());
	}
}

技术分享


XML解析器——DOM4j

标签:xml解析

原文地址:http://blog.csdn.net/emilyrr/article/details/42970051

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!