`

Dom4j使用

 
阅读更多

先来一段网上的废话:

om4j是一个Java的XML API,类似于jdom,用来读写XML文件的。dom4j是一个非常非常优秀的Java
XML API,具有性能优异、功能强大和极端易用使用的特点,同时它也是一个开放源代码的软件,可以在
SourceForge上找到它。在IBM developerWorks上面可以找到一篇文章,对主流的Java XML API进行的
性能、功能和易用性的评测,dom4j无论在那个方面都是非常出色的。如今你可以看到越来越多的Java软件都在
使用dom4j来读写XML,特别值得一提的是连Sun的JAXM也在用dom4j。这是必须使用的jar包,Hibernate
用它来读写配置文件。

 

注意,如果要使用Dom4j创建xml文档,只需要导入dom4j的jar包即可,如果要用dom4j解析xml文档,且使用xpath来解析,则需要导入jaxen-xx.xx.jar包,否则会报错。

 

下面来创建一个xml文档:


 

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-configuration PUBLIC "-//Hibernate/Hibernate Configuration DTD 3.0//EN" "http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">

<books>
  <!--这是添加的注释-->
  <firstbook name="飞翔的小鸟" price="12¥">
    <theauthor>
      <authorname>Stfen.Cofffe Orce</authorname>
      <otherbooks><![CDATA[《中国行》,《红花郎》,《哦哦地》...]]></otherbooks>
    </theauthor>
  </firstbook>
  <secondbook name="蚂蚁上树" price="23¥">
    <theauthor>
      <authorname>Wen Jim.Sam</authorname>
      <otherbooks><![CDATA[《哦看看》,《亚西门》....]]></otherbooks>
    </theauthor>
  </secondbook>
</books>

 

 

1.创建xml文档

 

package com.wang.test;
import org.dom4j.Document;
import org.dom4j.DocumentHelper;
import org.dom4j.Element;
import org.dom4j.Attribute;
import org.dom4j.io.OutputFormat;
import java.io.FileOutputStream;
import org.dom4j.io.XMLWriter;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
public class CreateXML {
	
	//创建log4j对象
	private static Log log = LogFactory.getLog(CreateXML.class);
	
	public static void main(String[] args){
		//创建xml文档对象
		Document document = DocumentHelper.createDocument();
		
		// 设置文档DocType,这里为了举例,添加hibernate的DocType 
	      document.addDocType("hibernate-configuration", 
	                   "-//Hibernate/Hibernate Configuration DTD 3.0//EN", 
	      "http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd");
		
		//创建文档的根节点books,文档的根节点只能有一个,多加会出错
		Element root = document.addElement("books");
		//添加一行注释
		root.addComment("这是添加的注释");
		//创建根节点的一级子节点firstbook
		Element bookOne = root.addElement("firstbook");
		//为节点firstbook添加属性
		bookOne.addAttribute("name", "飞翔的小鸟");
		bookOne.addAttribute("price", "12¥");
		//为节点firstbook添加子节点theauthor
		Element authorOne = bookOne.addElement("theauthor");
		//为节点theauthor添加子节点authorname
		Element nameOne = authorOne.addElement("authorname");
		//为authornamer节点添加文本节点
		nameOne.setText("Stfen.Cofffe Orce");
		//为节点theauthor添加子节点otherbooks
		Element booksOne = authorOne.addElement("otherbooks");
		//为节点othersbooks添加CDATA数据
		booksOne.addCDATA("《中国行》,《红花郎》,《哦哦地》...");
		
		 /** 
	       * 第二种方法增加节点,内容,属性等。先创建节点,属性,然后使用add加入。 
	       */ 
		//创建节点secondbook
		Element bookTwo = DocumentHelper.createElement("secondbook");
		//创建属性对象bookname,createAttribute的第一个参数表示该属性的拥有这者,可以写,也可为null
		Attribute bookname = DocumentHelper.createAttribute(bookTwo, "name", "蚂蚁上树");
		//创建属性对象bookPrice
		Attribute bookPrice = DocumentHelper.createAttribute(bookTwo, "price", "23¥");
		//将创建的属性添加到节点对象当中
		bookTwo.add(bookname);
		bookTwo.add(bookPrice);
		
		//创建节点author
		Element author = DocumentHelper.createElement("theauthor");
		Element authorName = DocumentHelper.createElement("authorname");
		authorName.setText("Wen Jim.Sam");
		Element otherbooks = DocumentHelper.createElement("otherbooks");
		otherbooks.addCDATA("《哦看看》,《亚西门》....");
		//将创建的节点authorName,otherbooks添加到author下
		author.add(authorName);
		author.add(otherbooks);		
		//将创建的节点author添加到节点bookTwo下
		bookTwo.add(author);
		
		//将创建的节点bookTwo添加到根节点root下,成为其一级节点
		root.add(bookTwo);
		
//		最后将生成的文档保存到文件当中
		
		//创建格式化类
		OutputFormat format = OutputFormat.createPrettyPrint();
		//设置编码格式
		format.setEncoding("UTF-8");
//		创建输出流,如果此处使用Writer的类,则需要指定输入的编码格式,
//		而使用OutputStream则不用指定编码格式
		FileOutputStream output = null;
		try{
			output = new FileOutputStream("D:\\books.xml");
//			创建XML输出流
			XMLWriter writer = new XMLWriter(output,format);
			writer.write(document);
			writer.close();
			output.close();
			log.debug("xml创建完成");
		}catch(Exception e){
			log.error(e);
		}	
		
	}
}

 2.修改xml文档。要修改,必须要找到修改的地方,也就是先解析xml文档,再修改目标。在解析xml文档时,有人会用传统的方式,也有人会用Xpath的方式,推荐使用xpath.下面贴个xpath的路径表,以供差用。

算了,发个xpath的教程地址吧:http://www.w3school.com.cn/xpath/xpath_syntax.asp  

 

修改xml文档:

 

public class ChangXml {
	private static Log log = LogFactory.getLog(ChangXml.class);
	public static void main(String[] args){
//		org.dom4j.io提供了两个类:SAXReader和DOMReader.
//		DOMReader只能一个现有的w3c DOM树构建 dom4j树,即只能从一个org.w3c.dom.Document 中构建org.dom4j.Document树;
//		而SAXReader则使用 SAX解析器,从不同的输入源构建dom4j树,如可以从xml文件中读取并构建dom4j树。 
		
////	1:使用DOMReader解析 
//		   DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance(); 
//		   DocumentBuilder db = dbf.newDocumentBuilder(); 
//		   File file = new File("d:/skills.xml"); 
//		   org.w3c.dom.Document domDocument = db.parse(file); 
//		   DOMReader reader = new DOMReader(); 
//		   org.dom4j.Document document = reader.read(domDocument); 

//		2:使用SAXReader解析 
		   SAXReader reader = new SAXReader(); 
		   Document document = null;
		   try{
			   document = reader.read(new File("d:/books.xml")); 			   
		   }catch(Exception e){
			   log.error(e);
		   }
		   
//		   将所有的authorname元素的文本修改为"wangyinan"
		   //根据xpath获得所有的authorname元素的文本值
		   //使用dom4j时调用XPath解析时, 要在项目中加入jaxen-xx.xx.jar
		   List authorNameList = document.selectNodes("//authorname");
		   for(Iterator iter = authorNameList.iterator();iter.hasNext();){
			   Element node = (Element)iter.next();
			   log.debug(node.getText());
			   //将属性值改为“wangyinan”
			   node.setText("wangyinan");
		   }
		   
//		   将所有的price属性值修改50美元
		   List priceList = document.selectNodes("//@price");
		   for(Iterator iter = priceList.iterator();iter.hasNext();){
			   Attribute attribute = (Attribute)iter.next();
			   log.debug("old value="+attribute.getValue());
			   attribute.setValue("50美元");
		   }
		   
//		   删除firstbook/theauthor元素下的otherbooks元素
		   
//		  由document文档对象不能直接删除节点 
//		   Element elementOhterbooks =(Element)document.selectSingleNode("/books/firstbook//otherbooks");
//		   log.debug(elementOhterbooks.getText());
//		   document.remove(elementOhterbooks);
		  
//		   元素不能删除其非直接子元素
////		   Element root = document.getRootElement();
//		   Element firstbook = (Element)document.selectSingleNode("/books/firstbook");
//		   Element otherbooks = (Element)document.selectSingleNode("/books/firstbook//otherbooks");
//		   log.debug(otherbooks.getText());
//		   firstbook.remove(otherbooks);
		   
		   Element theauthor =(Element)document.selectSingleNode("/books/firstbook//theauthor");
		   Element otherbooks = theauthor.element("otherbooks");
		   log.debug(otherbooks.getText());
		   theauthor.remove(otherbooks);
		  
		   
//		   修改后,要把修改的Document保存进文件内,不保存的话,修改成功不了
		   
//			创建格式化类
			OutputFormat format = OutputFormat.createPrettyPrint();
//			设置编码格式
			format.setEncoding("UTF-8");
//			创建输出流,如果此处使用Writer的类,则需要指定输入的编码格式,
//			而使用OutputStream则不用指定编码格式
			FileOutputStream output = null;
			try{
				output = new FileOutputStream("D:\\books.xml");
//				创建XML输出流
				XMLWriter writer = new XMLWriter(output,format);
				writer.write(document);
				writer.close();
				output.close();
				log.debug("chang success");
			}catch(Exception e){
				log.error(e);
			}
		   
	}
}

 

 

分享到:
评论

相关推荐

    dom4j使用手册

    dom4j使用手册;

    dom4j使用

    **DOM4J使用详解** DOM4J是一个Java库,它为XML处理提供了强大的功能,包括文档构建、查询、转换和事件处理。作为一个开源项目,DOM4J被广泛应用于各种Java应用中,尤其在处理大型XML文档时,其性能优势明显。 DOM...

    dom4j使用简介

    **DOM4J使用简介** DOM4J 是一个强大的 Java 库,专为处理 XML 文档而设计。它提供了丰富的 API,使得在 Java 中解析、创建、修改 XML 文件变得简单高效。DOM4J 不仅支持 DOM(文档对象模型)和 SAX(简单API for ...

    dom4j使用教程+dom4j.jar

    ### 四、DOM4J查询XML 1. **XPath查询**: DOM4J支持XPath表达式进行复杂查询。首先,需要创建`XPath`对象,并使用`compile()`方法编译XPath字符串,然后调用`evaluate()`方法执行查询。 ```java XPath xpath = ...

    Dom4j使用简介.pdf

    #### 四、Dom4j 的接口继承关系 为了更好地理解 Dom4j 的工作原理,我们需要了解它的接口继承关系。以下是部分关键接口的继承关系示意图: - `java.lang.Cloneable` → `org.dom4j.Node` - `org.dom4j.Attribute`...

    dom4j使用与jar包

    **DOM4J使用与JAR包** DOM4J是一个强大的Java库,专门用于处理XML文档。它提供了丰富的API,使得XML的读取、创建、修改和解析变得异常简便。在这个主题中,我们将深入探讨DOM4J的核心功能以及如何在Java项目中使用...

    DOM4J使用详解

    DOM4J是一个强大的Java库,专门用于处理XML文档。它提供了一种灵活且高效的方式来解析、创建、修改和操作XML文档。DOM4J不仅支持DOM模型,还支持SAX和JAXP解析器,使得开发者可以根据需要选择不同的解析策略。 1. ...

    Dom4j使用简介 帮助文档

    ### Dom4j 使用简介 #### 一、Dom4j 概述 Dom4j 是一个易用且功能强大的开源 XML 解析库,适用于 Java 平台。它支持 DOM、SAX 和 JAXP 标准,并且采用了 Java 集合框架进行数据管理。Dom4j 在设计上十分简洁,易于...

    Dom4j 使用指南.rar

    **Dom4j 使用指南** Dom4j 是一个非常流行的Java库,用于处理XML文档。它提供了灵活、高效的方式来解析、创建、操作XML内容。对于学习XML的开发者来说,Dom4j是一个不可多得的工具,因为它的API简洁易用,功能强大...

    dom4j 简单教程

    ### DOM4j 使用详解 #### 一、简介 DOM4j是一种用于处理XML文档的Java库,它提供了灵活且高效的方式来解析、修改和创建XML文件。相比于标准的DOM和SAX API,DOM4j提供了更加简洁易用的API,使得开发者能够更轻松地...

    XSD使用dom4j校验XML

    1. 加载XSD文件:使用DOM4J的DocumentHelper类的parse方法,传入XSD文件的路径,得到一个SchemaFactory对象。 ```java SchemaFactory schemaFactory = DocumentHelper.createSchema(new File("path_to_xsd_file.xsd...

    DOM4J 使用简介.pdf

    #### 四、DOM4J 的应用场景 DOM4J因其出色的性能和灵活性,被广泛应用于各种场景中,包括但不限于: - **Web服务**:在构建RESTful Web服务时,DOM4J可用于解析和生成XML响应。 - **配置管理**:许多软件系统使用...

    DOM4J jar包 xml解析 所有的dom4j-1.6.1 dom4j-2.0.2 dom4j-2.1.1包 导入直接使用

    在项目中使用DOM4J时,只需将相应的jar包(如dom4j-1.6.1.jar、dom4j-2.0.2.jar或dom4j-2.1.1.jar)导入到类路径中,即可开始利用其功能处理XML文档。导入后,可以按照DOM4J提供的API进行编程,快速实现XML的读写...

    dom4j中XPath用法

    要使用DOM4J的XPath功能,首先需要引入DOM4J库和JAXP(Java API for XML Processing),后者提供了XPath的实现。在Java项目中,这通常通过添加对应的依赖完成。例如,在Maven项目中,可以在pom.xml文件中加入以下...

    Dom4j使用简介

    Dom4j使用简介,日志 开发java必看,初级高级开发必看

    dom4j使用教程

    下面将详细讲解DOM4J的主要特性和使用方法。 ### 1. DOM4J的基本概念 - **Document**: XML文档的根节点,表示整个XML结构。 - **Element**: 表示XML文档中的元素,每个元素都有一个标签名,可以包含属性和子元素。...

    DOM4J 的使用

    DOM4J 的使用 DOM4J 是一个开源的 XML 解析包,由 dom4j.org 出品,应用于 Java 平台,采用了 Java 集合框架并完全支持 DOM、SAX 和 JAXP。DOM4J 的主要特点是使用大量的接口,所有主要接口都在 org.dom4j 里面定义...

Global site tag (gtag.js) - Google Analytics