DOM4J - 简介

是dom4j.org出品的一个开源XML解析包。Dom4j是一个易用的、开源的库,用于XML,XPath和XSLT。它应用于Java平台,采用了Java集合框架并完全支持DOM,SAX和JAXP。

DOM4J 使用起来非常简单。只要你了解基本的 XML-DOM 模型,就能使用。

Dom:把整个文档作为一个对象。

DOM4J 接口定义

它的主要接口都在org.dom4j里面定义

Attribute 定义了XML属性
Branch 只能够包含子节点的节点。如XML元素(Element)和文档(Document)定义了一个公共的行为
CDATA 定义了XML CDATA区域
CharacterData 是一个标识接口,标识基于字符的节点。如CDATA,Comment,Text
Comment 定义了XML注释的行为
Document 定义了XML文档
DocumentType 定义XML DOCTYPE声明
Element 定义XML元素
ElementHandler 定义了Element对象的处理器
ElementPath 被ElementHandler使用,用于取得当前正在处理的路径层次信息
Entity 定义了XML entity
Node 为dom4j中所有的XML节点定义了多态行为
NodeFilter 定义了在dom4j节点中产生的一个滤镜或谓词的行为(predicate)
ProcessingInstruction 定义XML处理指令
Text 定义XML文本节点
Visitor 用于实现Visitor模式
XPath 在分析一个字符串后会提供一个XPath表达式

接口之间的继承关系如下

● interface java.lang.Cloneable

● interface org.dom4j.Node

● interface org.dom4j.Attribute

● interface org.dom4j.

● interface org.dom4j.Document

● interface org.dom4j.Element

● interface org.dom4j.CharacterData

● interface org.dom4j.CDATA

● interface org.dom4j.Comment

● interface org.dom4j.Text

● interface org.dom4j.DocumentType

● interface org.dom4j.Entity

● interface org.dom4j.ProcessingInstruction

基本使用方式:

// 读取XML文件:创建ASXReader使用reader读取xml文件,获得Document对象:
SAXReader reader = new SAXReader();
Document document = reader.read("xml文件路径"); // 获取文档的根节点
Element root = document.getRootElement(); // 获取指定节点下的子节点
Element son_element = element.element("name"); // 获取节点的子节点集合
List<Element> elelist = element.elements();// 获取所有子节点
List<Element> son_elelist = element.elements(“name”);// 指定名称的子节点集合 // 获取节点属性的值
element.attributeValue("name"); // 获取元素内容
element.getText();

Element:定义XML元素

// 遍历所有子元素
Iterator elementIterator();// 遍历所有子元素
Iterator elementIterator("name");// 遍历指定名称子元素

Attribute:定义了XML的属性

getName();// 获取属性名
setName();// 设置属性名
getValue();// 获取属性值
setValue();// 设置属性值
getDocument();
setDocument();

DOM4J - XML文档操作

读取XML文件:读写XML文档主要依赖于org.dom4j.io包,有DOMReader和SAXReader两种方式。因为利用了相同的接口,它们的调用方式是一样的。

SAXReader reader = new SAXReader();

Document document = reader.read(new File("input.xml"));

         // 读取XML文件,获得document对象
SAXReader reader = new SAXReader();
Document doucument = reader.read("src/NewFile.xml");
// 获取根节点
Element root = doucument.getRootElement();
// System.out.println(e.getName());//打印根标签名字 // 遍历xml节点,elementIterator()方法获得它的子节点的Element对象们的一个迭代器
for (Iterator<Element> it = root.elementIterator(); it.hasNext();) { Element ele = it.next();
System.out.println(ele.getName());
if (ele.getName().equals("good")) {
Element name = ele.element("name");
if (name != null)
System.out.println(" -" + name.getText());
}
// Attribute获取属性,并进行遍历
for (Iterator<Attribute> i = ele.attributeIterator(); i.hasNext();) {
Attribute a = i.next();
System.out.println(" " + a.getName() + ":" + a.getText()); }
}

创建XML文件:使用DocumentHelper创建新的document,在document下添加root元素,然后可以再root元素下创建各种节点。

Document document = DocumentHelper.createDocument();

Element root = document.addElement("members");// 创建根节点

         // 建立document对象,用来操作xml文件
Document newDocument = DocumentHelper.createDocument();
// 建立根节点
Element newRoot = newDocument.addElement("root");
newRoot.addComment("This is a test for dom4j ");// 加入一行注释
// 添加一个authro1节点
Element authro1 = newRoot.addElement("authro");
  // 添加属性内容
  authro1.addAttribute("name", "James");
  authro1.addAttribute("location", "UK");
  // 添加文本节点
  authro1.addText("James Strachan");
// 添加一个authro2节点
Element authro1 = newRoot.addElement("authro");
   // 添加属性内容
  authro1.addAttribute("name", "James");
   authro1.addAttribute("location", "UK");
   // 添加文本节点
   authro1.addText("James Strachan");
try {
XMLWriter writer = new XMLWriter(new FileOutputStream("[路径/]filename"));
// 将Document对象写入xml文件中
writer.write(newDocument);
} catch (Exception e) {
e.printStackTrace();
} finally {
writer.close();// 关闭流
}

格式化输出Document,创建带有OutputFormat的XMLWriter可以实现对Document的格式化输出

         // 排版
OutputFormat format = OutputFormat.createPrettyPrint();
XMLWriter writer = new XMLWriter(new FileWriter("[path]filename"), format);
writer.write(document);// 将Document对象写入xml文件中
writer.close();// 关闭流
// 紧凑
OutputFormat format = OutputFormat.createCompactFormat();
XMLWriter writer = new XMLWriter(new FileWriter("[path]filename"), format);
writer.write(document);// 将Document对象写入xml文件中
writer.close();// 关闭流

写入XML文件中文乱码问题:http://blog.sina.com.cn/s/blog_757b0e130101dqrx.html

Document转成String
String xmlText = document.asXML();
 

DOM4J -(XML解析包)的更多相关文章

  1. Java XML解析工具 dom4j介绍及使用实例

    Java XML解析工具 dom4j介绍及使用实例 dom4j介绍 dom4j的项目地址:http://sourceforge.net/projects/dom4j/?source=directory ...

  2. 【Java】XML解析之DOM4J

    DOM4J介绍 dom4j是一个简单的开源库,用于处理XML. XPath和XSLT,它基于Java平台,使用Java的集合框架,全面集成了DOM,SAX和JAXP,使用需要引用dom4j.jar包 ...

  3. XML解析【介绍、DOM、SAX详细说明、jaxp、dom4j、XPATH】

    什么是XML解析 前面XML章节已经说了,XML被设计为"什么都不做",XML只用于组织.存储数据,除此之外的数据生成.读取.传送等等的操作都与XML本身无关! XML解析就是读取 ...

  4. xml之DOM方式解析,DOM4J工具解析原理

    DOM解析原理: DOM解析原理:xml解析器一次性把整个xml文档加载进内存,然后在内存中构建一颗Document的对象树,通过Document对象,得到树上的节点对象,通过节点对象访问(操作)到x ...

  5. XML概念定义以及如何定义xml文件编写约束条件java解析xml DTD XML Schema JAXP java xml解析 dom4j 解析 xpath dom sax

    本文主要涉及:xml概念描述,xml的约束文件,dtd,xsd文件的定义使用,如何在xml中引用xsd文件,如何使用java解析xml,解析xml方式dom sax,dom4j解析xml文件 XML来 ...

  6. java之xml解析-dom4j

    解析方式 XML 解析方式有很多种,但是常用的有两种,如下: DOM Document Object Model:把整个 XML 读到内存中,形成树状结构.整个文档为 Document 对象,属性为 ...

  7. xml解析 使用dom4j操作xml

     使用dom4j操作xml 1 导入 dom4j,的jar包   2 指定要解析的XML文件 SAXReader sr=new SAXReader(); Document document= sr.r ...

  8. java的XML解析(DOM4J技术)

    DOM4J技术解析XML文件 一,XML简介 xml (可扩展标记语言)  全称: Extended Markup Language 可扩展的含义:允许程序员按照自己的想法去扩展新的标签 注意:但是扩 ...

  9. XML 解析之 dom4j 解析器

    dom4j 的使用需要导入 jar 包, 包括: dom4j-1.6.1 和 jaxen-1.1-beta 步骤: 在项目目录下,"Folder" 创建一个 lib 文件夹 复制 ...

随机推荐

  1. Python 迭代器与生成器及装饰器

    1.迭代器(Iterator) 迭代器是访问集合元素的一种方式.有下面特点: 1)每次调用__next__()方法只访问一个元素,而且不能后退,便于循环比较大的数据集合,节省内存:(当容器中没有可访问 ...

  2. python元组与字典

    一.元组 1.元组的表达 (1,2,3,4) ('olive',123) ("python",) 创建元组: a=tuple((1,2,3,)) b=("python&q ...

  3. PAT甲级——A1126 Eulerian Path【30】

    In graph theory, an Eulerian path is a path in a graph which visits every edge exactly once. Similar ...

  4. 16.ajax_case09

    import requests import json import re from selenium import webdriver from selenium.webdriver.common. ...

  5. 《Python之BMI计算》

    <Python之BMI计算> 前段时间写了个 BMI 因为刚刚开始学 有几个错误 第一个: 厘米我当时也没注意因为觉得去掉0.00的话后面1866666666是正确的BMI值 刚刚去看看去 ...

  6. python pywin32学习笔记

    参考博客链接 https://blog.csdn.net/polyhedronx/article/details/81988948 参考博客链接 https://www.cnblogs.com/zha ...

  7. Crontab- Linux必学的60个命令

    1.作用 使用crontab命令可以修改crontab配置文件,然后该配置由cron公用程序在适当的时间执行,该命令使用权限是所有用户. 2.格式 crontab [ -u user ] 文件 cro ...

  8. 阶梯nim游戏

    阶梯nim游戏有n个阶梯,0-n-1,每个阶梯上有一堆石子,编号为i的阶梯上的石子只能移动到i-1上去,每次至少移动一个,最后所有的石子都移动到0号阶梯上了.结论:奇数阶梯上的石子异或起来,要是0,就 ...

  9. CentOS安装tomcat并且部署Java Web项目具有一定的参考价值

    本篇文章主要介绍了CentOS安装tomcat并且部署Java Web项目,具有一定的参考价值,有需要的可以了解一下.(http://m.8682222.com) 1.准备工作 b.因为tomcat的 ...

  10. HashMap四种遍历方式

    public static void main(String[] args){ Map<String,String> map = new HashMap<String, String ...