`

Dom4j解析XML基本操作

 
阅读更多
参考:http://blog.sina.com.cn/s/blog_4ab057eb0100e1z2.html
            http://hi.baidu.com/haveneagle/blog/item/acf9ebbf162d160118d81f3d.html

Dom4j 是一个易用的、开源的库,用于处理 XML、XPath 和 XSLT 。它应用于 Java 环境,采用了 Java 集合框架
并完全支持 DOM 、SAX 和 JAXP 。
 
要使用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 java.io.File;
import java.io.FileWriter;
import java.util.Iterator;
import java.util.List;

import org.dom4j.Attribute;
import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.DocumentHelper;
import org.dom4j.Element;
import org.dom4j.Node;
import org.dom4j.io.OutputFormat;
import org.dom4j.io.SAXReader;
import org.dom4j.io.XMLWriter;

 
以下是相关操作:
一.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 rootXmlText=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();
    }
  }

七. 使用DOM4J对XML文件操作-添加、修改、删除、获取元素节点

/**
*
* TODO 类
* @Project Name ${project_name}
* @author zhubo(朱波)
* @see mailto:zhubo@inspur.com
* @version 1.0
* @date: 2010-1-30
* XML文件操作封装类:添加元素、修改元素、删除元素、获取某个元素的值
*
* 修改记录:
* 日期              修改人                 描述
* -----------------------------------------------------------------------
*/

package com.inspur.plat.platcore.core;

import java.io.File;
import java.io.FileWriter;
import java.util.Iterator;
import java.util.List;

import org.dom4j.Attribute;
import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.DocumentHelper;
import org.dom4j.Element;
import org.dom4j.io.OutputFormat;
import org.dom4j.io.SAXReader;
import org.dom4j.io.XMLWriter;

public class XmlOperator {

private Document document;
private String filePath; //文件所在的实际物理路径
private WriteLog writelog;

public static void main(String[] args) {
   String filepath = System.getProperty("user.dir")+"/XmlFiles/LocalServicesConfig.xml";
  
   XmlOperator operator = new XmlOperator(filepath);
   operator.getXmlFile();
   //operator.addChild("item", "t1","services2", "");
   //operator.updateChild("item", "t1", "services2", "bb");
   //operator.deleteChild("item", "t1", "services2");
   String str = operator.getChild("item", "t3", "protocol");
   System.out.println(str);
}
public XmlOperator(String filepath){
   this.document = null;
   this.filePath = filepath;
   writelog = new WriteLog();
}
/**
* 创建XML文件
* @param rootName:根节点名称
*/
public void createXMLFile(String rootName) {
   if(!fileExist()){
    this.document = DocumentHelper.createDocument();
    this.document.addElement(rootName);
    saveXMLFile(this.document);
   }
}
/**
* 获取已存在的XML文档
* @return
*/
public Document getXmlFile() {
   if (fileExist()) {
    SAXReader reader = new SAXReader();
    try {
     this.document = reader.read(new File(filePath));
    } catch (DocumentException e) {
     String loginfo = StackTraceToString.getExceptionTrace(e);
     writelog.writeLogToEnd("LocalServerManager", loginfo);
    }finally{
     reader = null;
    }
   } else {
    //写日志
    String loginfo = "XML file does not exist,read error!";
    writelog.writeLogToEnd("LocalServerManager",loginfo);
    System.exit(0);
   }
   return this.document;
}
/**
* 添加元素
* @param fatherPath:父节点名称
* @param fatherattr:父节点属性
* @param childName:要添加的节点名称
* @param childValue:要添加的节点值
*/
public void addChild(String fatherNode, String fatherAttr,String childName, String childValue) {
   ChildOperator(fatherNode,fatherAttr,childName,childValue,"add");
}
/**
* 修改元素
* @param fatherPath:父节点名称
* @param fatherattr:父节点属性
* @param childName:要修改的节点名称
* @param childValue:要修改成的节点值
*/
public void updateChild(String fatherNode, String fatherAttr,String childName, String childValue) {
   ChildOperator(fatherNode,fatherAttr,childName,childValue,"update");
}
/**
* 删除元素
* @param fatherPath:父节点名称
* @param fatherattr:父节点属性
* @param childName:要删除的节点名称
*/
public void deleteChild(String fatherNode, String fatherAttr,String childName) {
   ChildOperator(fatherNode,fatherAttr,childName,"","delete");
}
/**
* 获取某个元素数值
* @param fatherPath:父节点名称
* @param fatherattr:父节点属性
* @param childName:要删除的节点名称
*/
public String getChild(String fatherNode, String fatherAttr,String childName) {
   String result = "";
   result = ChildOperator(fatherNode,fatherAttr,childName,"","get");
   return result;
}
/**
* 子节点操作
* @param fatherNode:父节点名称
* @param fatherAttr:父节点属性
* @param childName:要修改的节点
* @param childValue:修改后的节点值
* @param operator: 要执行的操作名称
*/
private synchronized String ChildOperator(String fatherNode, String fatherAttr,String childName, String childValue,String operator) {
   String result="";
   if (this.document == null) {
    //写日志
    String loginfo = "Has not get XML file, add err!";
    writelog.writeLogToEnd("LocalServerManager",loginfo);
    return "null";
   }
   Element root = this.document.getRootElement();//获取根节点名称
   if(!root.getName().equals(fatherNode)){ //如果不是在根节点下添加
    result = XmlElementOperator(root,fatherNode,fatherAttr,childName,childValue,operator);
   }else{
    if(operator.equals("add")){
     Element childelement = root.addElement(childName);//根节点不存在元素属性值
     childelement.setText(childValue);
     saveXMLFile(this.document);
    }else if(operator.equals("update")){
     List childelements = root.elements(childName);
     for(Iterator childs=childelements.iterator();childs.hasNext();){
      Element everyone = (Element)childs.next();
      everyone.setText(childValue); //修改该元素值
     }
     saveXMLFile(this.document);
    }else if(operator.equals("delete")){
     List childelements = root.elements(childName);//获取当前节点下的所有子节点,判断其值,以进行修改
     for(Iterator childs=childelements.iterator();childs.hasNext();){
      Element everyone = (Element)childs.next();
      root.remove(everyone);
     }
     saveXMLFile(this.document);
    }else if(operator.equals("get")){
     List childelements = root.elements(childName);//获取当前节点下的所有子节点,判断其值,以进行修改
     for(Iterator childs=childelements.iterator();childs.hasNext();){
      Element everyone = (Element)childs.next();
      result = everyone.getText();
     }
     saveXMLFile(this.document);
    }
   }
   return result;
}
/**
* 递归元素操作
* @param element:要递归的元素
* @param fatherNode:父节点名称
* @param fatherAttr:父节点属性
* @param childName:要进行操作的节点
* @param childValue:操作后的节点值
* @param operator: 要执行的操作名称
*/
private synchronized String XmlElementOperator(Element element,String fatherNode,String fatherAttr,String childName,String childValue,String operator){
   String result = "";
   List elements = element.elements();
   for(Iterator it=elements.iterator();it.hasNext();){
    Element currentelement = (Element)it.next();
    if(!currentelement.getName().equals(fatherNode)){ //当前元素并不是我们要查找的父元素时,继续查找
     XmlElementOperator(currentelement,fatherNode,fatherAttr,childName,childValue,operator);//递归调用
    }else{
     if(currentelement.attributeCount()>0){ //当前元素存在属性值时
      for(Iterator list=currentelement.attributeIterator();list.hasNext();){ //遍历属性值
       Attribute attr = (Attribute)list.next(); //获取属性值队列中的第一个元素
       if(attr.getValue().equals(fatherAttr)){//根据属性值确定惟一的父元素
        if(operator.equals("add")){//添加元素
         Element childelement = currentelement.addElement(childName); //给当前元素添加一个子元素
         childelement.setText(childValue); //设置子元素的数值
        }else if(operator.equals("update")){//修改某个元素
         List childelements = currentelement.elements(childName);//获取当前节点下的所有子节点,判断其值,以进行修改
         for(Iterator childs=childelements.iterator();childs.hasNext();){
          Element everyone = (Element)childs.next();
          everyone.setText(childValue); //修改该元素值
         }
        }else if(operator.equals("delete")){ //删除某个指定的元素
         List childelements = currentelement.elements(childName);//获取当前节点下的所有子节点,判断其值,以进行修改
         for(Iterator childs=childelements.iterator();childs.hasNext();){
          Element everyone = (Element)childs.next();
          currentelement.remove(everyone);
         }
        }else if(operator.equals("get")){
         List childelements = currentelement.elements(childName);//获取当前节点下的所有子节点,判断其值,以进行修改
         for(Iterator childs=childelements.iterator();childs.hasNext();){
          Element everyone = (Element)childs.next();
          result = everyone.getText();
         }
        }
        else{
         //写日志
         String loginfo = "XmlFile Operator not exists!";
         writelog.writeLogToEnd("LocalServerManager",loginfo);
        }
       }
      }
     }
    }
   }
   saveXMLFile(this.document);
   return result;
}
/**
* 保存XML文件
* @param document: XML文件名
*/
private void saveXMLFile(Document document) {
   try {
    OutputFormat format = OutputFormat.createPrettyPrint();
    format.setEncoding("utf-8");
    XMLWriter writer = new XMLWriter(new FileWriter(new File(filePath)),format);
    writer.write(document);   
    writer.close();
   } catch (Exception e) {   
    String loginfo = StackTraceToString.getExceptionTrace(e);
    writelog.writeLogToEnd("LocalServerManager", loginfo);
   }
}
/**
* 判断XML文件是否存在.
* @param fileName
* @return
*/
private boolean fileExist() {
   java.io.File objFile = new java.io.File(this.filePath);
   if (objFile.exists()) {
    return true;
   } else {
    return false;
   }

}
}

分享到:
评论

相关推荐

    dom4j解析xml详解

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

    使用 dom4j 解析 XML

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

    dom4j 解析写入xml

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

    java dom4j解析xml

    Java DOM4J解析XML是一种常见的处理XML文档的技术,它提供了灵活且高效的API,使得...通过理解上述DOM4J解析XML的基本概念、操作和示例,开发者可以有效地在Java项目中处理XML数据,无论是读取、创建还是修改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数据与业务对象关联时,反射机制显得尤为重要。

    使用dom4j解析XML

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

    java dom4j 解析xml的例子,可用

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

    dom4j解析XML所需要的jar包

    为了在Java项目中使用DOM4J解析XML,你需要将这两个jar文件(dom4j-1.6.1和jaxen-1.1-beta-7.jar)添加到你的类路径(classpath)中。这可以通过在IDE中配置构建路径,或者在命令行中指定 `-cp` 参数来完成。一旦...

Global site tag (gtag.js) - Google Analytics