Dom4j也可以很方便完成XML文档的创建、元素的修改、文档的查询遍历等,但dom4j稍比jdom复杂一点,不过在大片文档的情况下dom4j的性能要不jdom好。

准备

首先,提供相关的jar包

Dom4j jar包下载:

http://sourceforge.net/projects/dom4j/files/dom4j-2.0.0-ALPHA-2/

jaxen jar下载:

http://repo1.maven.org/maven2/jaxen/jaxen/1.1.1/jaxen-1.1.1.jar

和dom4j依赖或相关的jar:

http://dom4j.sourceforge.net/dependencies.html

Junit-jar下载:

http://ebr.springsource.com/repository/app/bundle/version/download?name=com.springsource.org.junit&version=4.8.1&type=binary

其次,准备测试案例的部分代码:

  1. package com.hoo.test;
  2. import java.io.File;
  3. import java.util.Iterator;
  4. import java.util.List;
  5. import org.dom4j.Attribute;
  6. import org.dom4j.Document;
  7. import org.dom4j.DocumentException;
  8. import org.dom4j.DocumentHelper;
  9. import org.dom4j.Element;
  10. import org.dom4j.Node;
  11. import org.dom4j.QName;
  12. import org.dom4j.dom.DOMAttribute;
  13. import org.dom4j.io.SAXReader;
  14. import org.dom4j.tree.BaseElement;
  15. import org.junit.After;
  16. import org.junit.Before;
  17. import org.junit.Test;
  18. public class DocumentTest {
  19. private SAXReader reader = null;
  20. @Before
  21. public void init() {
  22. reader = new SAXReader();
  23. }
  24. @After
  25. public void destory() {
  26. reader = null;
  27. System.gc();
  28. }
  29. public void fail(Object o) {
  30. if (o != null)
  31. System.out.println(o);
  32. }
  33. }

  

创建一篇XML文档

文档格式如下:

  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <catalog>
  3. <!--An XML Catalog-->
  4. <?target instruction?>
  5. <journal title="XML Zone" publisher="IBM developerWorks">
  6. <article level="Intermediate" date="December-2001">
  7. <title>Java configuration with XML Schema</title>
  8. <author>
  9. <firstname>Marcello</firstname>
  10. <lastname>Vitaletti</lastname>
  11. </author>
  12. </article>
  13. </journal>
  14. </catalog>

  

  1. @Test
  2. public void createDocument() {
  3. //创建一篇文档
  4. Document doc = DocumentHelper.createDocument();
  5. //添加一个元素
  6. Element root = doc.addElement("catalog");
  7. //为root元素添加注释
  8. root.addComment("An XML Catalog");
  9.  
  10. //添加标记
  11. root.addProcessingInstruction("target", "instruction");
  12.  
  13. //创建元素
  14. Element journalEl = new BaseElement("journal");
  15.  
  16. //添加属性
  17. journalEl.addAttribute("title", "XML Zone");
  18. journalEl.addAttribute("publisher", "IBM developerWorks");
  19. root.add(journalEl);
  20.  
  21. //添加元素
  22. Element articleEl = journalEl.addElement("article");
  23. articleEl.addAttribute("level", "Intermediate");
  24. articleEl.addAttribute("date", "December-2001");
  25. Element titleEl = articleEl.addElement("title");
  26.  
  27. //设置文本内容
  28. titleEl.setText("Java configuration with XML Schema");
  29. //titleEl.addText("Java configuration with XML Schema");
  30. Element authorEl = articleEl.addElement("author");
  31. authorEl.addElement("firstname").setText("Marcello");
  32. authorEl.addElement("lastname").addText("Vitaletti");
  33.  
  34. //可以使用 addDocType() 方法添加文档类型说明。
  35. doc.addDocType("catalog", null,"file://c:/Dtds/catalog.dtd");
  36. fail(doc.getRootElement().getName());
  37.  
  38. //将xml转换成文本
  39. fail(doc.asXML());
  40. //写入到文件
  41. }

  

* DocumentHelper是一个文档助手类(工具类),它可以完成文档、元素、文本、属性、注释、CDATA、Namespace、XPath的创建,以及利用XPath完成文档的遍历和将文本转换成Document;

parseText完成将xml字符串转换成Doc的功能

  1. Document doc = DocumentHelper.parseText("<root></root>");

  createDocument创建一个文档

  1. Document doc = DocumentHelper.createDocument();

  

如果带参数就会创建一个带有根元素的文档

createElement_x创建一个元素

  1. Element el = DocumentHelper.createElement_x("el");

  
* Document的addElement方法可以给当前文档添加一个子元素

  1. Element root = doc.addElement("catalog");

  * addComment方法可以添加一段注释

  1. root.addComment("An XML Catalog");

  

为root元素添加一段注释

* addProcessingInstruction添加一个标记

  1. root.addProcessingInstruction("target", "instruction");

  

为root元素添加一个标记

* new BaseElement可以创建一个元素

  1. Element journalEl = new BaseElement("journal");

  * addAttribute添加属性

  1. journalEl.addAttribute("title", "XML Zone");

  * add添加一个元素

  1. root.add(journalEl);

  

将journalEl元素添加到root元素中

* addElement添加一个元素,并返回当前元素

  1. Element articleEl = journalEl.addElement("article");

  

给journalEl元素添加一个子元素article

* setText、addText可以设置元素的文本

  1. authorEl.addElement("firstname").setText("Marcello");
  2. authorEl.addElement("lastname").addText("Vitaletti");

  * addDocType可以设置文档的DOCTYPE

  1. doc.addDocType("catalog", null,file://c:/Dtds/catalog.dtd);

  * asXML可以将文档或元素转换成一段xml字符串

  1. doc.asXML();
  2. root.asXML();

  * XMLWriter类可以把文档写入到文件中

  1. output = new XMLWriter(new FileWriter(new File("file/catalog.xml")));
  2. output.write(doc);
  3. output.close();

  # 修改XML文档内容

  1. @SuppressWarnings("unchecked")
  2. @Test
  3. public void modifyDoc() {
  4. try {
  5. Document doc = reader.read(new File("file/catalog.xml"));
  6. //修改属性内容
  7. List list = doc.selectNodes("//article/@level");
  8. Iterator<Attribute> iter = list.iterator();
  9. while (iter.hasNext()) {
  10. Attribute attr = iter.next();
  11. fail(attr.getName() + "#" + attr.getValue() + "#" + attr.getText());
  12. if ("Intermediate".equals(attr.getValue())) {
  13. //修改属性值
  14. attr.setValue("Introductory");
  15. fail(attr.getName() + "#" + attr.getValue() + "#" + attr.getText());
  16. }
  17. }
  18.  
  19. list = doc.selectNodes("//article/@date");
  20. iter = list.iterator();
  21. while (iter.hasNext()) {
  22. Attribute attr = iter.next();
  23. fail(attr.getName() + "#" + attr.getValue() + "#" + attr.getText());
  24. if ("December-2001".equals(attr.getValue())) {
  25. //修改属性值
  26. attr.setValue("December-2011");
  27. fail(attr.getName() + "#" + attr.getValue() + "#" + attr.getText());
  28. }
  29. }
  30. //修改节点内容
  31. list = doc.selectNodes("//article");
  32. Iterator<Element> it = list.iterator();
  33. while (it.hasNext()) {
  34. Element el = it.next();
  35. fail(el.getName() + "#" + el.getText() + "#" + el.getStringValue());
  36. //修改title元素
  37. Iterator<Element> elIter = el.elementIterator("title");
  38. while(elIter.hasNext()) {
  39. Element titleEl = elIter.next();
  40. fail(titleEl.getName() + "#" + titleEl.getText() + "#" + titleEl.getStringValue());
  41. if ("Java configuration with XML Schema".equals(titleEl.getTextTrim())) {
  42. //修改元素文本值
  43. titleEl.setText("Modify the Java configuration with XML Schema");
  44. fail(titleEl.getName() + "#" + titleEl.getText() + "#" + titleEl.getStringValue());
  45. }
  46. }
  47. }
  48. //修改节点子元素内容
  49. list = doc.selectNodes("//article/author");
  50. it = list.iterator();
  51. while (it.hasNext()) {
  52. Element el = it.next();
  53. fail(el.getName() + "#" + el.getText() + "#" + el.getStringValue());
  54. List<Element> childs = el.elements();
  55. for (Element e : childs) {
  56. fail(e.getName() + "#" + e.getText() + "#" + e.getStringValue());
  57. if ("Marcello".equals(e.getTextTrim())) {
  58. e.setText("Ayesha");
  59. } else if ("Vitaletti".equals(e.getTextTrim())) {
  60. e.setText("Malik");
  61. }
  62. fail(e.getName() + "#" + e.getText() + "#" + e.getStringValue());
  63. }
  64. }
  65. //写入到文件
  66. } catch (DocumentException e) {
  67. e.printStackTrace();
  68. } catch (Exception e) {
  69. e.printStackTrace();
  70. }
  71. }

  

* reader.read(new File("file/catalog.xml"));读取指定xml文件内容到文档中;

* selectNodes是XPath的查询方法,完成xml文档的查询,传递xpath路径。其使用方法可以参考jdom的xpath的使用方法:

http://www.cnblogs.com/hoojo/archive/2011/08/11/2134638.html

* getName获取元素标签名称、getValue、getText获取值、文本内容;

* elementIterator("title");获取当前节点下所有的title元素,返回Iterator;

* elements获取下面所有的子元素,返回的是一个集合List;

显示文档相关信息

  1. private String format(int i) {
  2. String temp = "";
  3. while (i > 0) {
  4. temp += "--";
  5. i--;
  6. }
  7. return temp;
  8. }
  9.  
  10. private void print(int i, List<Element> els) {
  11. i++;
  12. for (Element el : els) {
  13. fail(format(i) + "##" + el.getName() + "#" + el.getTextTrim());
  14. if (el.hasContent()) {
  15. print(i, el.elements());
  16. }
  17. }
  18. }
  19.  
  20. @Test
  21. public void printInfo() {
  22. try {
  23. Document doc = reader.read(new File("file/catalog.xml"));
  24. fail("asXML: " + doc.asXML());
  25. fail(doc.asXPathResult(new BaseElement("article")));
  26. List<Node> list = doc.content();
  27. for (Node node : list) {
  28. fail("Node: " + node.getName() + "#" + node.getText() + "#"
  29. + node.getStringValue());
  30. }
  31. fail("-----------------------------");
  32. print(0, doc.getRootElement().elements());
  33. fail("getDocType: " + doc.getDocType());
  34. fail("getNodeTypeName: " + doc.getNodeTypeName());
  35. fail("getPath: " + doc.getRootElement().getPath());
  36. fail("getPath: "
  37. + doc.getRootElement().getPath(new BaseElement("journal")));
  38. fail("getUniquePath: " + doc.getRootElement().getUniquePath());
  39. fail("getXMLEncoding: " + doc.getXMLEncoding());
  40. fail("hasContent: " + doc.hasContent());
  41. fail("isReadOnly: " + doc.isReadOnly());
  42. fail("nodeCount: " + doc.nodeCount());
  43. fail("supportsParent: " + doc.supportsParent());
  44. } catch (DocumentException e) {
  45. e.printStackTrace();
  46. }
  47. fail("getEncoding: " + reader.getEncoding());
  48. fail("isIgnoreComments: " + reader.isIgnoreComments());
  49. fail("isMergeAdjacentText: " + reader.isMergeAdjacentText());
  50. fail("isStringInternEnabled: " + reader.isStringInternEnabled());
  51. fail("isStripWhitespaceText: " + reader.isStripWhitespaceText());
  52. fail("isValidating: " + reader.isValidating());
  53. }

  # 删除文档内容

  1. @Test
  2. public void removeNode() {
  3. try {
  4. Document doc = reader.read(new File("file/catalog-modified.xml"));
  5. fail("comment: " + doc.selectSingleNode("//comment()"));
  6. // 删除注释
  7. doc.getRootElement().remove(doc.selectSingleNode("//comment()"));
  8. Element node = (Element) doc.selectSingleNode("//article");
  9. // 删除属性
  10. node.remove(new DOMAttribute(QName.get("level"), "Introductory"));
  11. // 删除元素 节点
  12. node.remove(doc.selectSingleNode("//title"));
  13. // 只能删除下一级节点,不能超过一级;(需要在父元素的节点上删除子元素)
  14. Node lastNameNode = node.selectSingleNode("//lastname");
  15. lastNameNode.getParent().remove(lastNameNode);
  16. fail("Text: " + doc.selectObject("//*[text()='Ayesha']"));
  17. Element firstNameEl = (Element) doc.selectObject("//firstname");
  18. fail("Text: " + firstNameEl.selectSingleNode("text()"));
  19. // 删除text文本
  20. // firstNameEl.remove(firstNameEl.selectSingleNode("text()"));
  21. // firstNameEl.remove(doc.selectSingleNode("//firstname/text()"));
  22. firstNameEl.remove(doc
  23. .selectSingleNode("//*[text()='Ayesha']/text()"));
  24. // 删除子元素author
  25. // node.remove(node.selectSingleNode("//author"));
  26. fail(doc.asXML());
  27. } catch (Exception e) {
  28. e.printStackTrace();
  29. }
  30. }

  * 删除注释

  1. doc.getRootElement().remove(doc.selectSingleNode("//comment()"));

  

删除root元素下面的注释

* 删除属性(可以删除非命名空间的属性)

  1. node.remove(new DOMAttribute(QName.get("level"), "Introductory"));

  

删除node节点中的名称为level,其值为Introductory的属性

* 删除元素

  1. node.remove(doc.selectSingleNode("//title"));

  

删除node节点下的title元素

* 删除文本

  1. firstNameEl.remove(firstNameEl.selectSingleNode("text()"));
  2. firstNameEl.remove(doc.selectSingleNode("//firstname/text()"));
  3. firstNameEl.remove(doc.selectSingleNode("//*[text()='Ayesha']/text()"));

  删除firstNameEl的文本内容

Dom4J对XML的创建、修改、删除等操作的更多相关文章

  1. Linux创建修改删除用户和组

    Linux 创建修改删除用户和组 介绍 在日常的维护过程中创建用户操作用的相对会多一些,但是在这个过程中涉及到的知识点就不单单就是useradd了,接下来就来详细了解账号管理的相关信息. 用户信息 先 ...

  2. oracle11g创建修改删除表

    oracle11g创建修改删除表 我的数据库名字: ORCL         密码:123456 1.模式 2.创建表 3.表约束 4.修改表 5.删除表 1.模式 set oracle_sid=OR ...

  3. MySQL进阶11--DDL数据库定义语言--库创建/修改/删除--表的创建/修改/删除/复制

    /*进阶 11 DDL 数据库定义语言 库和表的管理 一:库的管理:创建/修改/删除 二:表的管理:创建/修改/删除 创建: CREATE DATABASE [IF NOT EXISTS] 库名; 修 ...

  4. Linux基础学习-用户的创建修改删除

    用户添加修改删除 1 useradd添加用户 添加一个新用户hehe,指定uid为3000,家目录为/home/haha [root@qdlinux ~]# useradd -u 3000 -d /h ...

  5. Java使用DOM4J对XML文件进行增删改查操作

    Java进行XML文件操作,代码如下: package com.founder.mrp.util; import java.io.File; import java.util.ArrayList; i ...

  6. .net操作xml文件(新增.修改,删除,读取) 转

    今天有个需求需要操作xml节点.突然见遗忘了许多.上网看了些资料.才整出来.脑袋真不够用.在这里把我找到的资料共享一下.方便以后使用.本文属于网摘/ 1 一.简单介绍2 using System.Xm ...

  7. Linux 创建修改删除用户和组

    200 ? "200px" : this.width)!important;} --> 介绍 在日常的维护过程中创建用户操作用的相对会多一些,但是在这个过程中涉及到的知识点就 ...

  8. ElasticSearch.net NEST批量创建修改删除索引完整示例

    本示例采用Elasticsearch+Nest 网上查了很多资料,发现用C#调用Elasticsearch搜索引擎的功能代码很分散,功能不完整,多半是非常简单的操作,没有成型的应用示例.比如新增或修改 ...

  9. MySQL入门很简单: 4 创建 修改删除表

    1. 创建表的方法 1)创建表的语法形式 首先,选择数据库: USE 数据库名: 创建表: CREATE TABLE 表名 (属性名 数据类型 [完整性约束条件], 属性名 数据类型 [完整性约束条件 ...

随机推荐

  1. sjtu1591 Count On Tree

    Description Crystal家有一棵树.树上有\(n\)个节点,编号由\(1\)到\(n\)(\(1\)号点是这棵树的根),两点之间距离为1当且仅当它们直接相连.每个点都有各自的权值,第\( ...

  2. sublime text 2 前端编码神器-快捷键与使用技巧介绍

    介绍网址:http://www.xuanfengge.com/sublime-text-2-artifact.html

  3. POJ2222+暴力搜索

    一共2^15个状态 比较简单 /* 2^15 states */ #include<stdio.h> #include<string.h> #include<stdlib ...

  4. centos 5.x 升级openssl

    今日想在centos 5.2上面安装mysql 5.5.37,在make的时候提示: Linking C shared module adt_null.so [ 65%] Built target a ...

  5. Linux配置系统

    配置架构: 三元素: 配置文件, 环境变量, 命令行选项 三级别: 系统级,用户级,程序级 应用: 调用时可能发生变化的配置信息,使用命令行选项:改动很少但确实应该由各个用户自己控制的配置信息,使用用 ...

  6. Uva 12361 File Retrieval 后缀数组+并查集

    题意:有F个单词,1 <= F <=60 , 长度<=10^4, 每次可以输入一个字符串,所有包含该字串的单词会形成一个集合. 问最多能形成多少个不同的集合.集合不能为空. 分析:用 ...

  7. Altium自定义的快捷键设置

    我想要在AD09里面设置自定义的快捷键,例如将布线设置成键盘上的字母E键,如何设置求大神指点!感激不尽!!! 为什么快捷键都要发一篇文章呢?主要是AD换层的快捷键是*号,与其他快捷键离的很远,一个AD ...

  8. (?m)

    centos6.5:/root/sbin#cat -n vv 1 192.168.11.186,192.168.11.187 35199,3306 Dec 7, 2016 11:40:02.75052 ...

  9. 【原创】FPGA开发手记(三) PS/2键盘

    以下内容均以Xilinx的Nexys3作为开发板   1.PS/2键盘简介 虽然Nexys3开发板是利用USB接口搭载键盘,但是其原理与PS/2键盘完全相同,现在就仅以PS/2键盘为例讲解如何将键盘搭 ...

  10. Android开发之启动Activity的最佳写法

    从MainActivity跳转到SecondActivity 在SecondActivity中,写一个静态方法actionStart() public static void actionStart( ...