`

Dom4j解析XML的基本操作

    博客分类:
  • Java
阅读更多

要使用dom4j读写XML文档,需要先下载dom4j包
dom4j官方网站在 http://www.dom4j.org/
下载dom4j-1.6.1.zip
解开后有两个包,仅操作XML文档的话把dom4j-1.6.1.jar加入工程就可以了,如果需要使用XPath的话还需要加入包jaxen-1.1-beta-7.jar
 
类开头引入:

 

import org.dom4j.io.SAXReader;   
import org.dom4j.Document;   
import org.dom4j.DocumentException;   
import org.dom4j.Element;   
import org.dom4j.Node;   
  
import java.util.Iterator;   
import java.util.List;   
import java.io.*;
 以下是相关操作:

一.Document对象相关
1.读取XML文件,获得document对象.

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

 2.解析XML形式的文本,得到document对象.

String text = "<members></members>";   
Document document = DocumentHelper.parseText(text);  

 3.主动创建document对象.

Document document = DocumentHelper.createDocument();   
Element root = document.addElement("members");// 创建根节点  
 二.节点相关

1.获取文档的根节点.

Element rootElm = document.getRootElement();  

2.取得某节点的单个子节点.

Element memberElm=root.element("member");// "member"是节点名 

3.取得节点的文字

String text=memberElm.getText();  

 也可以用:

String text=root.elementText("name");这个是取得根节点下的name字节点的文字.  

4.取得某节点下名为"member"的所有字节点并进行遍历.

List nodes = rootElm.elements("member");   
for (Iterator it = nodes.iterator(); it.hasNext();) {   
   Element elm = (Element) it.next();   
   // do something   
} 

5.对某节点下的所有子节点进行遍历.

for(Iterator it=root.elementIterator();it.hasNext();){   
    Element element = (Element) it.next();   
    // do something   
}  

6.在某节点下添加子节点.

Element ageElm = newMemberElm.addElement("age");  

7.设置节点文字.

ageElm.setText("29"); 

8.删除某节点.

parentElm.remove(childElm);// childElm是待删除的节点,parentElm是其父节点  

 获取一个Element之后可以进行的相关操作:

attributue(String name) :获取元素String值。   
elementIterator() :返回元素的所有子元素的Iterator迭代器。   
elements() :返回元素包含所有子元素List。   
getParent() :获取父元素Element。   
getPath() :获取自己的xpath。   
detach() :移除自己。   
getName() :获取节点的名称。   
selectNodes(String xpathExpression) :通过XPATH获取节点。   
selectSingleNode(String xpathExpression) :通过XPATH获取一个节点。   
getDocument() :作为一个Document返回。  
 三.属性相关

1.取得某节点下的某属性

Element root=document.getRootElement();      
Attribute attribute=root.attribute("size");// 属性名name

2.取得属性的文字

String text=attribute.getText();  

 也可以用:

String text2=root.element("name").attributue("firstname");  
 这个是取得根节点下name字节点的属性firstname的值.

 
3.遍历某节点的所有属性

Element root=document.getRootElement();      
for(Iterator it=root.attributeIterator();it.hasNext();){   
    Attribute attribute = (Attribute) it.next();   
    String text=attribute.getText();   
    System.out.println(text);   
}  

4.设置某节点的属性和文字.

newMemberElm.addAttribute("name", "sitinspring");  

5.设置属性的文字

Attribute attribute=root.attribute("name");   
attribute.setText("sitinspring");  

6.删除某属性

Attribute attribute=root.attribute("size");// 属性名name   
root.remove(attribute);  
 四.将文档写入XML文件

1.文档中全为英文,不设置编码,直接写入的形式.

XMLWriter writer = new XMLWriter(new FileWriter("output.xml"));   
writer.write(document);   
writer.close();  

2.文档中含有中文,设置编码格式写入的形式.

OutputFormat format = OutputFormat.createPrettyPrint();   
format.setEncoding("GBK");    // 指定XML编码          
XMLWriter writer = new XMLWriter(new FileWriter("output.xml"),format);   
  
writer.write(document);   
writer.close();  
 五.字符串与XML的转换

1.将字符串转化为XML

String text = "<members> <member>sitinspring</member> </members>";   
Document document = DocumentHelper.parseText(text);  

2.将文档或节点的XML转化为字符串.

SAXReader reader = new SAXReader();   
Document  document = reader.read(new File("input.xml"));              
Element root=document.getRootElement();                  
String docXmlText=document.asXML();   
String rootrootXmlText=root.asXML();   
Element memberElm=root.element("member");   
String memberXmlText=memberElm.asXML();  
 六.使用XPath快速找到节点

读取的XML文档示例

<?xml version="1.0" encoding="UTF-8"?>  
<projectDescription>  
  <name>MemberManagement</name>  
  <comment></comment>  
  <projects>  
    <project>PRJ1</project>  
    <project>PRJ2</project>  
    <project>PRJ3</project>  
    <project>PRJ4</project>  
  </projects>  
  <buildSpec>  
    <buildCommand>  
      <name>org.eclipse.jdt.core.javabuilder</name>  
      <arguments>  
      </arguments>  
    </buildCommand>  
  </buildSpec>  
  <natures>  
    <nature>org.eclipse.jdt.core.javanature</nature>  
  </natures>  
</projectDescription>

 使用XPath快速找到节点project.

public static void main(String[] args){   
   SAXReader reader = new SAXReader();   
     
   try{   
     Document  doc = reader.read(new File("sample.xml"));   
     List projects=doc.selectNodes("/projectDescription/projects/project");   
     Iterator it=projects.iterator();   
     while(it.hasNext()){   
       Element elm=(Element)it.next();         
       System.out.println(elm.getText());   
     }   
       
   }   
   catch(Exception ex){   
      ex.printStackTrace();   
   }   
 }  

 

 

[转自:http://ajava.org/course/xml/12141.html]

分享到:
评论

相关推荐

    dom4j解析xml详解

    ### DOM4J解析XML详解 #### 一、DOM4J简介与特性 DOM4J是一个由dom4j.org开发的开源XML解析包,专为Java平台设计,它不仅支持DOM、SAX和JAXP标准,还巧妙地融入了Java集合框架,使其成为Java开发者在处理XML数据时...

    使用 dom4j 解析 XML

    使用 dom4j 解析 XML dom4j 解析 XML dom4j解析xml

    java dom4j解析xml

    Java DOM4J解析XML是一种常见的处理XML文档的技术,它提供了灵活且高效的API,使得...通过理解上述DOM4J解析XML的基本概念、操作和示例,开发者可以有效地在Java项目中处理XML数据,无论是读取、创建还是修改XML文件。

    dom4j 解析写入xml

    1、xml文档解析 2、 dom4j解析xml 3、实现xml文件解析 xml字符串解析 xml MAP键值对解析 4、实现xml写入与生成文件

    dom4j解析xml文件的压缩包

    为了使用这个库,你需要将该jar包添加到项目的类路径中,然后就可以通过DOM4J提供的类和方法来解析和操作XML文件了。 总之,DOM4J是一个功能强大的XML处理库,无论是在小型项目还是大型系统中,都能发挥其优势,...

    dom4j解析xml文件(增删改查)

    在“dom4j解析xml文件(增删改查)”这个主题中,我们将深入探讨如何使用DOM4J来实现XML文档的四种基本操作:增加元素、删除元素、更新元素内容以及查询元素。 首先,让我们了解DOM4J的基本用法。在解析XML文件时,...

    dom4j解析xml实例

    通过学习和实践这些基本操作,你可以熟练掌握DOM4J解析XML的技巧,为你的Java项目中处理XML数据提供强大的支持。在项目中遇到具体问题时,可以参考DOM4J的官方文档,或利用在线资源进行更深入的学习。

    DOM4J 解析XML

    **DOM4J解析XML** DOM4J是一个强大的Java库,专门用于处理XML文档。它提供了灵活、高效且功能丰富的API,使得XML的读取、创建、修改和查询变得简单易行。DOM4J的主要特点包括对XPath的支持、事件驱动的解析、以及与...

    dom4j解析xml

    **DOM4J解析XML的基本步骤** 1. **创建Document**: 首先,需要创建一个`Document`对象,这通常是通过解析XML文件完成的。例如,使用`DocumentHelper.parseText()`或`SAXReader.read()`方法。 2. **访问Element**: ...

    dom4j解析XML所需jar包

    6. **XPath和XSLT转换**:除了基本的XML操作,DOM4J还能配合XPath执行XSLT(eXtensible Stylesheet Language Transformations)转换,实现XML到XML或XML到其他格式(如HTML)的转换。 7. **JAXB集成**:虽然DOM4J...

    dom4j 解析xml实例

    通过这个实例,我们可以学习到DOM4J解析XML的基本操作,包括加载XML文件、访问和修改元素、以及保存更改。这只是一个简单的例子,DOM4J库还提供了更高级的功能,如XPath查询、事件驱动的处理模式等,可以满足更复杂...

    dom4j 解析(读取) xml 节点数据

    在本教程中,我们将深入探讨如何使用DOM4J解析(读取)XML节点数据,不受XML层级的限制。 首先,确保你已经下载了必要的依赖,即DOM4J库。通常,这将是一个名为`dom4j-x.x.x.jar`的文件,其中x.x.x是DOM4J的版本号...

    dom4j解析XML

    本人自己研究的解析方法,主要用dom4j解析XML文件,进而获取里面的信息

    dom4j解析xml文件代码示例

    在本示例中,我们将深入探讨如何使用DOM4J解析XML文件,以`CacheInit.java`作为我们的核心代码示例,并参考`emailTemplateConfig.xml`作为实际操作的对象。 首先,让我们了解XML(eXtensible Markup Language)。...

    dom4j解析xml,利用反射机制

    通过这种方式,我们可以利用DOM4J解析XML文件,同时借助Java反射机制将解析结果动态地映射到自定义的Java类中。这在处理XML数据时提供了很大的灵活性,尤其在需要将XML数据与业务对象关联时,反射机制显得尤为重要。

    java dom4j 解析xml的例子,可用

    1. **DOM4J解析XML**:DOM4J通过创建一个可操作的树形结构来表示XML文档,这棵树称为文档对象模型。解析XML时,DOM4J首先读取XML文件并构建一个节点结构,然后你可以通过API遍历和修改这个结构。例如,你可以通过...

    使用dom4j解析XML

    【使用dom4j解析XML】 dom4j是一个强大的开源XML框架,它提供了处理XML文档的各种功能,包括解析、创建、修改等。相比W3C DOM API,dom4j的优势在于其内置的XPath支持,允许更方便地定位和操作XML文档中的节点。 *...

    分别使用DOM和DOM4j解析XML文件

    以下是如何使用DOM4j解析XML: 1. 引入DOM4j库(如:dom4j-1.6.1.jar)。 2. 创建DocumentFactory实例。 3. 使用DocumentFactory的read()方法读取XML文件,得到Document对象。 4. 使用Document对象提供的方法(如...

Global site tag (gtag.js) - Google Analytics