java解析xml文件(三种方式-(dom ,jdom ,dom4j)

标签: java 解析 xml | 发表时间:2012-09-20 01:47 | 作者:
出处:http://www.iteye.com

test.xml文件

<?xml version="1.0" encoding="UTF-8"?>   
<HD>   
  <disk name="C">   
    <capacity>8G</capacity>   
    <directories>200</directories>   
    <files>1580</files>   
  </disk>   
  
  <disk name="D">   
    <capacity>10G</capacity>   
    <directories>500</directories>   
    <files>3000</files>   
  </disk>   
</HD> 

   

第一种,利用dom方式解析xml 文件,无需jar包

package Dom;
import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import org.w3c.dom.Document;
import org.w3c.dom.Element;
import org.w3c.dom.NodeList;

public class DomXML {
	
	public static void main(String[] args)throws Exception {
	    //得到DOM解析器的工厂实例
	    DocumentBuilderFactory dbFactory = DocumentBuilderFactory.newInstance();
	    //从DOM工厂中获得DOM解析器
	    DocumentBuilder dbBuilder = dbFactory.newDocumentBuilder();
	    //声明为File为了识别中文名
	    Document doc = null;
		doc = dbBuilder.parse("F:/work_sapce_petroskill/Spring/src/Dom/test.xml");
		
		//得到文档名称为Student的元素的节点列表
		NodeList list = doc.getElementsByTagName("disk");
		
		//遍历该集合,显示结合中的元素及其子元素的名字
		for(int i = 0; i< list.getLength() ; i ++){
			Element element = (Element)list.item(i);
			String name=element.getAttribute("name");
			String capacity=element.getElementsByTagName("capacity").item(0).getFirstChild().getNodeValue();
			String directories=element.getElementsByTagName("directories").item(0).getFirstChild().getNodeValue();
			String files=element.getElementsByTagName("files").item(0).getFirstChild().getNodeValue();
			System.out.println("磁盘信息:"); 
	        System.out.println("分区盘符:"+name); 
	        System.out.println("分区容量:"+capacity); 
	        System.out.println("目录数:"+directories); 
	        System.out.println("文件数:"+files); 
	        System.out.println("-----------------------------------"); 
		}      
  	}
 }

 

输出结果为:

磁盘信息:
分区盘符:C
分区容量:8G
目录数:200
文件数:1580
-----------------------------------
磁盘信息:
分区盘符:D
分区容量:10G
目录数:500
文件数:3000
-----------------------------------

   

第二种,利用Jdom方式解析xml文件,需要下载jdom.jar(见附件)

 

package Dom;
import java.util.List;

import org.jdom.Document;
import org.jdom.Element;
import org.jdom.input.SAXBuilder;
public class JDomXML { 
  public static void main(String[] args) throws Exception{  
    SAXBuilder sb=new SAXBuilder(); 
    Document doc=sb.build(Dom4jXML.class.getClassLoader().getResourceAsStream("Dom/test.xml")); //构造文档对象
    Element root=doc.getRootElement(); //获取根元素
    List list=root.getChildren("disk");//取名字为disk的所有元素 
    for(int i=0;i<list.size();i++){ 
       Element element=(Element)list.get(i); 
       String name=element.getAttributeValue("name"); 
       String capacity=element.getChildText("capacity");//取disk子元素capacity的内容 
       String directories=element.getChildText("directories"); 
       String files=element.getChildText("files"); 
       System.out.println("磁盘信息:"); 
       System.out.println("分区盘符:"+name); 
       System.out.println("分区容量:"+capacity); 
       System.out.println("目录数:"+directories); 
       System.out.println("文件数:"+files); 
       System.out.println("-----------------------------------"); 
    }   
  } 
} 

 

 

输出结果为:

磁盘信息:
分区盘符:C
分区容量:8G
目录数:200
文件数:1580
-----------------------------------
磁盘信息:
分区盘符:D
分区容量:10G
目录数:500
文件数:3000
-----------------------------------

 

第三种,利用dom4j方式解析xml文件,需要下载 dom4j-1.6.1.jar(见附件)

package Dom;
import java.util.Iterator;
import org.dom4j.Document;
import org.dom4j.Element;
import org.dom4j.io.SAXReader;

public class Dom4jXML{   
   public static void main(String[] args) throws Exception {
	
        //创建文件对象   
        java.io.File file=new java.io.File("F:/workSapce/javaXML/src/Dom/test.xml");   
        //创建一个读取XML文件的对象   
        SAXReader reader=new SAXReader();   
        //创建一个文档对象   
        Document document=reader.read(file);   
        //获取文件的根节点   
        Element element=document.getRootElement();
        for(Iterator i=element.elementIterator("disk");i.hasNext();){
        	//获取节点元素   
            element=(Element)i.next();
        	String name=element.attributeValue("name");
            String capacity=element.elementText("capacity");//取disk子元素capacity的内容 
            String directories=element.elementText("directories"); 
            String files=element.elementText("files"); 
            System.out.println("磁盘信息:"); 
            System.out.println("分区盘符:"+name); 
            System.out.println("分区容量:"+capacity); 
            System.out.println("目录数:"+directories); 
            System.out.println("文件数:"+files); 
            System.out.println("-----------------------------------"); 
        }   
    }   
}  
       

 

输出结果为:

磁盘信息:
分区盘符:C
分区容量:8G
目录数:200
文件数:1580
-----------------------------------
磁盘信息:
分区盘符:D
分区容量:10G
目录数:500
文件数:3000
-----------------------------------

 

 

总结:DOM4J性能最好

           小文档情况下还值得考虑使用DOM和JDOM





已有 0 人发表留言,猛击->> 这里<<-参与讨论


ITeye推荐



相关 [java 解析 xml] 推荐:

java解析xml数据---sax解析器

- - ITeye博客
下面是handler解析数据的方法. private HashMap map = null;// 存储单个解析的完整对象. private List> list = null;// 存储全部的解析对象. private String currentTag = null; // 正在解析的元素的标签.

android 或者java SAX解析XML

- - ITeye博客
本实例解析xml使用的是继承DefaultHandler类,此类就是java中封装好的xml解析器类,下面看代码详细说明:. 第一步:首先说明下xml文件,Java Sax解析是按照xml文件的顺序一步一步的来解析,在解析xml文件之前,我们要先了解xml文件的节点的种类,一种是ElementNode,一种是TextNode.

java中多种方式解析xml

- - Java - 编程语言 - ITeye博客
DOM的全称是Document Object Model,也即文档对象模型. 在应用程序中,基于DOM的XML分析器将一个XML文档转换成一个对象模型的集合(通常称DOM树),应用程序正是通过对这个对象模型的操作,来实现对XML文档数据的操作. 通过DOM接口,应用程序可以在任何时候访问XML文档中的任何一部分数据,因此,这种利用DOM接口的机制也被称作随机访问机制.

xml sax解析

- - 移动开发 - ITeye博客
最近一直在做接口,主要用对xml的解析用的是sax,下面我对sax的几种写法做了一个测试:. System.out.println("耗时:"+(end-start));. System.out.println("当前 Java 虚拟机中的使用内存量:" + (freeMemory01-freeMemory02) + " 字节");.

java解析xml文件(三种方式-(dom ,jdom ,dom4j)

- - ITeye博客
第一种,利用dom方式解析xml 文件,无需jar包. //得到DOM解析器的工厂实例. //从DOM工厂中获得DOM解析器. //声明为File为了识别中文名. //得到文档名称为Student的元素的节点列表. //遍历该集合,显示结合中的元素及其子元素的名字. System.out.println("磁盘信息:");.

Android PULL解析XML

- - CSDN博客移动开发推荐文章
int eventType = parser.getEventType();//产生第一个事件. while(eventType!=XmlPullParser.END_DOCUMENT){//只要不是文档结束事件. String name = parser.getName();//获取解析器当前指向的元素的名称.

Android DOM解析XML

- - CSDN博客移动开发推荐文章
if(personChilds.item(y).getNodeType()==Node.ELEMENT_NODE){//判断当前节点是否是元素类型节点. 作者:jaycee110905 发表于2013-2-7 21:04:29 原文链接. 阅读:78 评论:0 查看评论.

Java中4种XML解析与创建方式的例子与速度测试

- - IT瘾-jianshu
在慕课看java工程师的路径课程,看完了java的对xml文件读取与写入,在这里对这四种操作方式做个记录. 这里对于DOM和SAX各自的优缺点的不进行讨论了,主要将各自的操作步骤,和解析、创建进行列举,并对他们的速度进行检测. 基于以上1和2方式,需要导入jar包. 基于以上1和2方式,需要导入jar包.

javascript之XML DOM的解析

- - ITeye博客
javascript之XML DOM的解析. . 长春. 吉林市. 四平. 松原. 通化. .

Java写xml文件的编码问题

- - CSDN博客推荐文章
最近项目中需要生成xml格式的配置文件,用的是 javax.xml.transform.Transformer 类中提供的transform方法,在本地执行没问题,但是一旦把工程部署到Tomcat下运行,就会出现中文乱码的现象,纠结了许久,在大神的帮助下终于解决了. 有篇文章其实已经讲的很清楚了,链接如下:.