- 浏览: 76913 次
- 性别:
- 来自: z驻马店
文章分类
最新评论
先来一段网上的废话:
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); } } }
发表评论
-
java动态代理小记
2012-10-30 17:48 1162这两天没有什么工作任务,也不想去看所谓的业务,就利用闲来的时间 ... -
javascript encodURI() 和 JAVA URLDecoder.decode
2012-08-08 11:11 1468Js中 encodURI(encodURI(xxxx)),在j ... -
AOP总结
2012-05-30 08:52 981自己对AOP的总结,粘贴效果不好,就上传附件吧 -
2012-2013要读的书
2012-05-23 18:37 02012年-2013年要读的书 《thiking in ... -
关于js中"window.location.href"、"location.href"
2012-04-12 17:08 843关于js中"window.location.href ... -
javascript 两个相同的字符串,js判断却不一致
2012-04-07 18:06 4669今天做项目时遇到一个奇怪的问题,struts2+ajax,返回 ... -
debug单步调试的用法
2012-03-20 08:56 1186f5 run into 进入方法内部f6 执行下一行代码f7 ... -
dwr错误
2012-03-20 08:58 855一、dwr遇到这种错误: org.directwebremot ... -
往eclipse中导入项目
2012-03-20 08:57 40281. 怎么从svn服务器上把项目下载下来 首先新 ... -
qc错误
2012-02-07 12:37 987如果QC报出如 “在 "BEGIN-OF-STAT ... -
取表中字段值重复的一条数据
2011-12-28 17:20 1031表 t_a, 有三个字段 id,name,age 有 ... -
hibernate.current_session_context_class 错误
2011-12-27 15:24 891在使用SessionFactory的getCurrentSes ... -
SELECT INTO 和 INSERT INTO SELECT 两种表复制语句
2011-12-27 10:14 808Insert是T-sql中常用语句,Insert INTO t ... -
java多线程相关
2011-12-26 09:40 751自己写的关于java多线程方面的总结和笔记 -
Java的SPI机制
2011-12-02 15:39 691SPI的全名为Service Provider Interfa ... -
关于TomCat自动加载class问题
2011-12-01 16:49 3292每次用tomcat的时候,每当我对类做了修改必须要重新启动to ... -
Eclipse无法自动编译的问题
2011-11-21 10:37 1135今天遇到了一个小问题,就是eclipse下导入的工程都无法 ... -
struts2对AJAX的支持
2011-11-11 13:46 1484struts2确实一个非常棒的MVC框架。这里部分记述一下st ... -
转:DynaBean 的使用
2011-11-08 11:21 3970DynaBean 的使用 在正常的开发的过程 ... -
HttpSession , HttpSessionListener , HttpSessionBindingListener , HttpSessionAtri
2011-10-26 16:35 829原来我一直认为只有当 ...
相关推荐
dom4j使用手册;
**DOM4J使用详解** DOM4J是一个Java库,它为XML处理提供了强大的功能,包括文档构建、查询、转换和事件处理。作为一个开源项目,DOM4J被广泛应用于各种Java应用中,尤其在处理大型XML文档时,其性能优势明显。 DOM...
**DOM4J使用简介** DOM4J 是一个强大的 Java 库,专为处理 XML 文档而设计。它提供了丰富的 API,使得在 Java 中解析、创建、修改 XML 文件变得简单高效。DOM4J 不仅支持 DOM(文档对象模型)和 SAX(简单API for ...
### 四、DOM4J查询XML 1. **XPath查询**: DOM4J支持XPath表达式进行复杂查询。首先,需要创建`XPath`对象,并使用`compile()`方法编译XPath字符串,然后调用`evaluate()`方法执行查询。 ```java XPath xpath = ...
**DOM4J使用与JAR包** DOM4J是一个强大的Java库,专门用于处理XML文档。它提供了丰富的API,使得XML的读取、创建、修改和解析变得异常简便。在这个主题中,我们将深入探讨DOM4J的核心功能以及如何在Java项目中使用...
DOM4J是一个强大的Java库,专门用于处理XML文档。它提供了一种灵活且高效的方式来解析、创建、修改和操作XML文档。DOM4J不仅支持DOM模型,还支持SAX和JAXP解析器,使得开发者可以根据需要选择不同的解析策略。 1. ...
### Dom4j 使用简介 #### 一、Dom4j 概述 Dom4j 是一个易用且功能强大的开源 XML 解析库,适用于 Java 平台。它支持 DOM、SAX 和 JAXP 标准,并且采用了 Java 集合框架进行数据管理。Dom4j 在设计上十分简洁,易于...
**Dom4j 使用指南** Dom4j 是一个非常流行的Java库,用于处理XML文档。它提供了灵活、高效的方式来解析、创建、操作XML内容。对于学习XML的开发者来说,Dom4j是一个不可多得的工具,因为它的API简洁易用,功能强大...
### DOM4j 使用详解 #### 一、简介 DOM4j是一种用于处理XML文档的Java库,它提供了灵活且高效的方式来解析、修改和创建XML文件。相比于标准的DOM和SAX API,DOM4j提供了更加简洁易用的API,使得开发者能够更轻松地...
1. 加载XSD文件:使用DOM4J的DocumentHelper类的parse方法,传入XSD文件的路径,得到一个SchemaFactory对象。 ```java SchemaFactory schemaFactory = DocumentHelper.createSchema(new File("path_to_xsd_file.xsd...
#### 四、DOM4J 的应用场景 DOM4J因其出色的性能和灵活性,被广泛应用于各种场景中,包括但不限于: - **Web服务**:在构建RESTful Web服务时,DOM4J可用于解析和生成XML响应。 - **配置管理**:许多软件系统使用...
在项目中使用DOM4J时,只需将相应的jar包(如dom4j-1.6.1.jar、dom4j-2.0.2.jar或dom4j-2.1.1.jar)导入到类路径中,即可开始利用其功能处理XML文档。导入后,可以按照DOM4J提供的API进行编程,快速实现XML的读写...
要使用DOM4J的XPath功能,首先需要引入DOM4J库和JAXP(Java API for XML Processing),后者提供了XPath的实现。在Java项目中,这通常通过添加对应的依赖完成。例如,在Maven项目中,可以在pom.xml文件中加入以下...
Dom4j使用简介,日志 开发java必看,初级高级开发必看
下面将详细讲解DOM4J的主要特性和使用方法。 ### 1. DOM4J的基本概念 - **Document**: XML文档的根节点,表示整个XML结构。 - **Element**: 表示XML文档中的元素,每个元素都有一个标签名,可以包含属性和子元素。...
DOM4J 的使用 DOM4J 是一个开源的 XML 解析包,由 dom4j.org 出品,应用于 Java 平台,采用了 Java 集合框架并完全支持 DOM、SAX 和 JAXP。DOM4J 的主要特点是使用大量的接口,所有主要接口都在 org.dom4j 里面定义...