`
yufenfei
  • 浏览: 801059 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

dom4j解析XML(二)

    博客分类:
  • XML
阅读更多

修改文档  

  

这一节说明如何使用 dom4j API 修改示例 XML 文档 catalog.xml。  

  

使用 SAXReader 解析 XML 文档 catalog.xml:  

  

SAXReader saxReader = new SAXReader();  

Document document = saxReader.read(inputXml);   

  

  

SAXReader 包含在 org.dom4j.io 包中。   

  

inputXml 是从 c:/catalog/catalog.xml 创建的 java.io.File。使用 XPath 表达式从 article 元素中获得 level 节点列表。如果 level 属性值是“Intermediate”则改为“Introductory”。   

  

List list = document.selectNodes("//article/@level" );  

       Iterator iter=list.iterator();  

        while (iter.hasNext()){  

             Attribute attribute=(Attribute)iter.next();  

               if (attribute.getValue().equals( "Intermediate" ))  

                attribute.setValue("Introductory" );   

        }   

  

  

获取 article 元素列表,从 article 元素中的 title 元素得到一个迭代器,并修改 title 元素的文本。   

  

list = document.selectNodes("//article" );  

      iter=list.iterator();  

   while (iter.hasNext()){  

        Element element=(Element)iter.next();  

       Iterator iterator=element.elementIterator("title" );  

   while (iterator.hasNext()){  

    Element titleElement=(Element)iterator.next();  

   if (titleElement.getText().equals( "Java configuration with XML Schema" ))  

      titleElement.setText("Create flexible and extensible XML schema" );  

     }}   

  

  

通过和 title 元素类似的过程修改 author 元素。   

  

清单 4 所示的示例程序 Dom4JParser.java 用于把 catalog.xml 文档修改成 catalog-modified.xml 文档。  

  

清单 4 . 用于修改 catalog.xml 的程序(Dom4Jparser.java)   

import org.dom4j.Document;  

import org.dom4j.Element;  

import org.dom4j.Attribute;  

import java.util.List;  

import java.util.Iterator;  

import org.dom4j.io.XMLWriter;  

import java.io.*;  

import org.dom4j.DocumentException;  

import org.dom4j.io.SAXReader;   

public class Dom4JParser{  

public void modifyDocument(File inputXml){  

  try {  

    SAXReader saxReader = new SAXReader();  

    Document document = saxReader.read(inputXml);  

    List list = document.selectNodes("//article/@level" );  

    Iterator iter=list.iterator();  

   while (iter.hasNext()){  

    Attribute attribute=(Attribute)iter.next();  

    if (attribute.getValue().equals( "Intermediate" ))  

      attribute.setValue("Introductory" );   

       }  

     

    list = document.selectNodes("//article/@date" );  

    iter=list.iterator();  

   while (iter.hasNext()){  

     Attribute attribute=(Attribute)iter.next();  

    if (attribute.getValue().equals( "December-2001" ))  

       attribute.setValue("October-2002" );  

        }  

    list = document.selectNodes("//article" );  

    iter=list.iterator();  

   while (iter.hasNext()){  

     Element element=(Element)iter.next();  

     Iterator iterator=element.elementIterator("title" );  

      while (iterator.hasNext()){  

         Element titleElement=(Element)iterator.next();  

        if (titleElement.getText().equals("Java configuration with XML  

       Schema"))  

         titleElement.setText("Create flexible and extensible XML schema" );  

                                           }  

                                 }  

    list = document.selectNodes("//article/author" );  

     iter=list.iterator();  

     while (iter.hasNext()){  

      Element element=(Element)iter.next();  

      Iterator iterator=element.elementIterator("firstname" );  

     while (iterator.hasNext()){  

       Element firstNameElement=(Element)iterator.next();  

      if (firstNameElement.getText().equals( "Marcello" ))  

       firstNameElement.setText("Ayesha" );  

                                      }  

                               }  

     list = document.selectNodes("//article/author" );  

     iter=list.iterator();  

     while (iter.hasNext()){  

       Element element=(Element)iter.next();  

       Iterator iterator=element.elementIterator("lastname" );  

     while (iterator.hasNext()){  

       Element lastNameElement=(Element)iterator.next();  

      if (lastNameElement.getText().equals( "Vitaletti" ))  

       lastNameElement.setText("Malik" );  

                                   }  

                                }  

      XMLWriter output = new XMLWriter(  

      new FileWriter( new File( "c:/catalog/catalog-modified.xml" ) ));  

      output.write( document );  

      output.close();  

    }  

   

  catch (DocumentException e)  

                  {  

                   System.out.println(e.getMessage());  

                             }  

  catch (IOException e){  

                        System.out.println(e.getMessage());  

                     }  

}  

public static void main(String[] argv){  

   Dom4JParser dom4jParser=new Dom4JParser();  

   dom4jParser.modifyDocument(new File( "c:/catalog/catalog.xml" ));  

                                         }  

    }  

分享到:
评论

相关推荐

    dom4j解析xml详解

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

    Dom4j解析XML文档.doc

    无论是读取XML文件,解析XML字符串,还是创建、修改和遍历XML结构,DOM4J都提供了简洁的接口,极大地简化了开发者的工作。在实际的开发中,掌握DOM4J的使用,能够帮助你更有效地处理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,使得开发者能够方便地读取、写入、修改以及操作XML文件。DOM4J是Java中一个非常强大的XML处理库,它结合了DOM、SAX和JDOM的优点,同时也...

    dom4j解析xml文件的压缩包

    5. **事件驱动解析(SAX)**:除了传统的DOM解析外,DOM4J还支持SAX解析器,这种解析方式适用于处理大型XML文件,因为它不需要一次性加载整个文档到内存。 6. **Namespace支持**:DOM4J提供了对XML命名空间的全面...

    DOM4J 解析XML

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

    dom4j解析xml实例

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

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

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

    dom4j解析xml

    ### DOM4J解析XML知识点详解 #### 一、DOM4J简介 DOM4J是一个Java库,用于处理XML文档。它的设计目标是为了提供一个简单、易于使用的API来处理XML文件,同时保持性能上的优势。与Java标准库中的DOM实现相比,DOM4J...

    dom4j解析XML所需jar包

    2. **XML解析**:DOM4J支持多种解析方式,包括SAX(Simple API for XML)和DOM。SAX是基于事件的解析,适用于处理大文件;DOM则将整个XML文档加载到内存,适合小规模或内存允许的情况。DOM4J还提供了StAX(Streaming...

    dom4j 解析xml实例

    在这个实例中,我们将深入探讨如何使用DOM4J解析XML文件,并通过`Dom4jTest1.java`这个示例程序来理解其工作原理。 首先,我们需要了解XML(Extensible Markup Language)是一种标记语言,常用于存储和传输数据。...

    dom4j解析XML

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

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

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

    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