`
lancijk
  • 浏览: 388385 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

DOM4J 解析XML 添加 删除 修改

阅读更多

 

这里贴了代码 ..还整了一个压缩包!

 

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.DocumentHelper;
import org.dom4j.Element;
import org.dom4j.io.OutputFormat;
import org.dom4j.io.SAXReader;
import org.dom4j.io.XMLWriter;


/**
*
* @author estcele
*/
public class Dom4jDemo {
    
    /** Creates a new instance of Dom4jDemo */
    public Dom4jDemo() {
    }
    /**
     *The method createXML
     *建立一个XML文档,文档名由输入属性决定
     *@param filename 需建立的文件名
     *@return 返回操作结果
     */
    public boolean createXML(String fileName){
        boolean isOk = false;
        //建立document对象
        Document doc = DocumentHelper.createDocument();
        //建立XML文档的根books
        Element books = doc.addElement("books");
        books.addComment("This is a test for dom4j");//加入一行注释
        Element book = books.addElement("book");//加入第一个book节点
        book.addAttribute("show", "yes");//加入show属性内容
        Element title = book.addElement("title");//加入title节点
        title.setText("Dom4j Tutorials");//为title设置内容
        /**加入第二个book节点*/
        book = books.addElement("book");
        book.addAttribute("show", "yes");
        title = book.addElement("title");
        title.setText("Lucene Studing");
        /**加入第三个book节点*/
        book = books.addElement("book");
        book.addAttribute("show", "no");
        title = book.addElement("title");
        title.setText("Lucene in Action");
        /**加入owner节点*/
        Element owner = books.addElement("owner");
        owner.setText("O'Reilly");
        /**
         *将doc中的内容写入xml文件中
         **/
        try{
            FileWriter file = new FileWriter(new File(fileName));
            XMLWriter writer = new XMLWriter(file);
            writer.write(doc);
            writer.close();
            isOk = true;
        }catch(Exception e){
            e.printStackTrace();
        }
        return isOk;
    }
   /**
     *the method modifigXML
     *     如果book节点中show属性的内容为yes,则修改成no
     *     把owner项内容改为Tshinghua,并添加date节点
     *     若title内容为Dom4j Tutorials,则删除该节点
     */
    public boolean modifigXML(String oldFileName,String newFileName){
        boolean isOk = false;
        try{
            SAXReader reader = new SAXReader();
            Document doc = reader.read(new File(oldFileName));
            /**修改内容之一: 如果book节点中show属性的内容为yes,则修改成no*/
            List list = doc.selectNodes("/books/book/@show");
            Iterator iter = list.iterator();
            while(iter.hasNext()){
                Attribute attr = (Attribute)iter.next();
                if(attr.getValue().equals("yes"))
                    attr.setValue("no");
            }
            /**
             *修改内容之二: 把owner项内容改为Tshinghua
             *并在owner节点中加入date节点,
             * date节点的内容为2004-09-11,
             * 还为date节点添加一个属性type
             */
            list = doc.selectNodes("/books/owner");
            iter = list.iterator();
            if(iter.hasNext()){
                Element owner = (Element)iter.next();
                owner.setText("Tshinghua");
                Element date = owner.addElement("date");
                date.setText("2006-07-30");
                date.addAttribute("type", "Gregorian calendar");
            }
           /**修改内容之三: 若title内容为Dom4j Tutorials,则删除该节点*/
            list = doc.selectNodes("/books/book");
            iter = list.iterator();
            while(iter.hasNext()){
                Element elem = (Element)iter.next();
                Iterator iterElem = elem.elementIterator("title");
                if(iterElem.hasNext()){
                    Element remTitle = (Element)iterElem.next();
                    if(remTitle.getText().trim().equals("Dom4j Tutorials"))
                        elem.remove(remTitle);
                }
            }
            //将doc中的内容写入文件中
            try{
                FileWriter newFile = new FileWriter(new File(newFileName));
                XMLWriter newWriter = new XMLWriter(newFile);
                newWriter.write(doc);
                newWriter.close();
            }catch(Exception e){
                e.printStackTrace();
            }
            isOk = true;
        }catch(Exception e){
            e.printStackTrace();
        }
        return isOk;
    }
    /**
     *the method formatXML
     *-------------------------
     *默认的输出方式为紧凑方式,默认编码为UTF-8,
     * 但对于我们的应用而言,一般都要用到中文,
     * 并且希望显示时按自动缩进的方式的显示,这就需用到OutputFormat类。
     */
    public boolean formatXML(String fileName){
        boolean isOk = false;
        try{
            SAXReader reader = new SAXReader();
            Document doc = reader.read(new File(fileName));
            XMLWriter formatWriter = null;
            /**
             *格式化输出,类型IE浏览一样
             *指定XML编码
             */
            OutputFormat format = OutputFormat.createPrettyPrint();
            format.setEncoding("gb2312");
            formatWriter = new XMLWriter(new FileWriter(new File(fileName)), format);
            formatWriter.write(doc);
            formatWriter.close();

            isOk = true;
        }catch(Exception e){
            e.printStackTrace();
        }
        return isOk;
    }
   /**
     *the method readXML
     */
    public void readXML(String fileName){
        try{
            SAXReader reader = new SAXReader();
            Document doc = reader.read(new File(fileName));
            List list = doc.selectNodes("/books/book");
            Iterator iter = list.iterator();
            while(iter.hasNext()){
                Element book = (Element)iter.next();
                Iterator title = book.elementIterator("title");
                if(title.hasNext()){
                    Element elemTitle = (Element)title.next();
                    System.out.print("Title: "+elemTitle.getText());
                    System.out.print("   Show: "+book.attributeValue("show")+"\n");
                }
            }
            
            list = doc.selectNodes("/books/owner");
            iter = list.iterator();
            if(iter.hasNext()){
                Element owner = (Element)iter.next();
                System.out.println("Owner: "+owner.getText());
                System.out.println("Date: "+owner.elementText("date"));
            }
        }catch(Exception e){
            e.printStackTrace();
        }
    }
   /*
    Title: Dom4j Tutorials   Show: yes
    Title: Lucene Studing   Show: yes
    Title: Lucene in Action   Show: no
   Owner: O'Reilly
   Date: null
    */
    /**
     *the method main
     */
    public static void main(String[] args){
        long start = System.currentTimeMillis();//开始计时
        Dom4jDemo dom4jDemo = new Dom4jDemo();
        String fileName = "dom4jDemo.xml";
        String newFileName = "new_dom4jDemo.xml";
        System.out.println(fileName+"正在创建中...");
        boolean isOk_create = dom4jDemo.createXML(fileName);
        if(isOk_create) System.out.println(fileName+"创建成功!");
        else System.out.println("创建失败!请检查后重新再试!");
        
        System.out.println("正在更新中...");
        boolean isOk_modi = dom4jDemo.modifigXML(fileName, newFileName);
        if(isOk_modi) System.out.println("恭喜,更新完成!");
        else System.out.println("更新失败!请检查后重新再试!");
        
        System.out.println("正在格式化中...");
        boolean isOk_format = dom4jDemo.formatXML(fileName);
        if(isOk_format) System.out.println("恭喜,格式化完成!");
        else System.out.println("格式化失败!请检查后重新再试!");
        
        System.out.println("正在读取文件 "+fileName+" ...");
        System.out.println("------------------------------------------------");
        dom4jDemo.readXML(fileName);
        System.out.println("------------------------------------------------");
        System.out.println(fileName+"读取成功!");
        System.out.println("正在读取文件 "+newFileName+" ...");
        System.out.println("------------------------------------------------");
        dom4jDemo.readXML(newFileName);
        System.out.println("------------------------------------------------");
        System.out.println(fileName+"读取成功!");
        System.out.println("一共耗时: "+(System.currentTimeMillis()-start)+"毫秒!");
    }
}

 

 

 

引用自:http://hi.baidu.com/kingdomislet/blog/item/2b4876543aac845f564e0092.html

分享到:
评论

相关推荐

    java dom4j解析xml

    Java DOM4J解析XML是一种常见的处理XML文档的技术,它提供了灵活且高效的API,使得开发者能够方便地读取、写入、修改以及操作XML文件。DOM4J是Java中一个非常强大的XML处理库,它结合了DOM、SAX和JDOM的优点,同时也...

    dom4j解析xml文件的压缩包

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

    dom4j解析xml实例

    **DOM4J解析XML实例详解** 在Java编程中,处理XML文档是一项常见的任务。DOM4J是一个非常流行的、强大的Java XML API,它提供了灵活且高效的方式来解析、创建、修改XML文档。本文将深入探讨如何使用DOM4J进行XML...

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

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

    dom4j解析XML所需jar包

    5. **XML文档操作**:DOM4J提供了丰富的API,如添加、删除、移动和复制XML节点,以及修改节点内容和属性值。这些功能使得对XML文档的维护和更新变得非常方便。 6. **XPath和XSLT转换**:除了基本的XML操作,DOM4J还...

    dom4j解析xml

    **DOM4J解析XML** DOM4J是一个Java库,它为处理XML提供了强大的功能,包括读取、写入、修改和操作XML文档。这个库以其灵活性、效率和易用性而受到开发者的青睐。DOM4J是基于DOM(Document Object Model)的,但它...

    java dom4j 解析xml的例子,可用

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

    dom4j解析XML文档.ppt

    DOM4J是一个强大的Java库,专门用于解析XML文档。它提供了简单易用的API,使得开发者可以更加方便地处理XML数据。DOM4J的核心优势在于它的面向接口编程设计,这使得它能够在不同的解析机制间灵活切换,如DOM、SAX和...

    Java使用sax、dom、dom4j解析xml文档

    以下是一个DOM4J解析XML的简单示例: ```java import org.dom4j.Document; import org.dom4j.DocumentHelper; import org.dom4j.Element; public class Dom4jExample { public static void main(String[] args) {...

    dom4j解析xml.txt

    ### DOM4J解析XML知识点详解 #### 一、DOM4J简介 DOM4J(Document Object Model for XML)是一款用于处理XML文档的轻量级Java库。它提供了一种非常简单且灵活的方式来创建、读取、修改和删除XML文档。DOM4J的主要...

    xmldom4j解析

    三、DOM4J解析XML 1. 创建Document对象:使用`DocumentFactory`创建XML文档的根元素,然后逐步构建整个文档。 2. 读取XML文件:通过`DocumentHelper.parseText()`或`SAXReader.read()`方法读取XML文件到Document对象...

    dom4j-jar与dom4j解析xml文档介绍

    "dom4j-jar与dom4j解析xml文档介绍" 这个标题告诉我们,我们将探讨的是一个关于dom4j库的jar文件,以及如何使用这个库来解析XML文档。dom4j是一个Java库,它提供了丰富的API用于处理XML、HTML和DOM文档。这里的"jar...

    DOM4J解析XML数据

    这个示例展示了如何使用DOM4J解析XML文件,访问和遍历元素,使用XPath查询,以及添加新元素并序列化到新的XML文件。 总之,DOM4J是Java开发中处理XML文档的利器,它简化了XML的解析、操作和生成过程,使得开发者能...

    DOM4J解析XML

    1. **DOM解析方式**:DOM4J通过DOM接口来解析XML,将整个XML文档加载到内存中形成一个树形结构,称为DOM树。这样做的优点是可以方便地通过路径导航访问任何元素,缺点是如果XML文件过大,可能会消耗大量内存。 2. *...

    dom4j解析XML所需要的包

    下面我们将深入探讨DOM4J解析XML的基本概念、使用方法以及它与其他XML解析器的比较。 XML(eXtensible Markup Language)是一种标记语言,广泛应用于数据交换、配置文件和文档结构化存储。DOM4J是基于DOM(Document...

    dom4j解析xml详解,包含源代码,dom4j.jar包

    本篇将深入讲解DOM4J解析XML的原理与实践,同时提供相关源代码供参考。 一、DOM4J概述 DOM4J是基于DOM模型的,但它比Java标准的DOM API更轻量级,性能更优。DOM4J的主要特点包括: 1. 支持XPath:DOM4J提供了对...

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

    在本教程中,我们将深入探讨如何使用DOM4J来执行基本的XML操作,包括添加元素、修改元素、删除元素以及获取元素节点。 1. **添加元素节点** 在DOM4J中,添加元素节点通常涉及创建一个新的`Element`对象,然后将其...

    dom4j---xml解析jar包

    在Java环境中,解析XML文档时,我们通常会遇到各种库,其中DOM4J是一个非常流行的、功能强大的开放源代码库。这个库不仅简化了XML处理,还提供了XPath和XSLT的支持,使其成为Java开发者处理XML的首选工具之一。 **...

Global site tag (gtag.js) - Google Analytics