`

dom4j隨意記一下

阅读更多

package com.topthinking.tel.test.dom4j;

import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;
import java.rmi.RemoteException;
import java.util.Iterator;
import java.util.List;
import java.util.Properties;

import javax.xml.rpc.ServiceException;

import org.apache.axis.message.MessageElement;
import org.dom4j.Attribute;
import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.DocumentHelper;
import org.dom4j.Element;
import org.dom4j.QName;

import com._28tel.www.GetAllCurrencyResponseGetAllCurrencyResult;
import com._28tel.www.WebService_28TelLocator;
import com._28tel.www.WebService_28TelSoap;

public class ReadXMLByDom {
    public static void main(String [] args) throws DocumentException, ServiceException, IOException{
        ReadXMLByDom r = new ReadXMLByDom();
//        r.readXMLAllAttr();
//        r.readXMLAllElement();
//        r.readXMLAttr();
//        r.readXMLElement();
        
        
//        //遍历某节点下的一级节点
//        String str = "<diffgr><books><book id='1'><Name new = 'haha' >Java</Name><price>100</price><test>haoren</test></book>";
//        str = str + "<book id='2'><Name>Linux</Name><price>100</price></book></books></diffgr>";
//        Document document = DocumentHelper.parseText(str);
//        List list = document.selectNodes("/diffgr/books/book" );
//        Iterator it = list.iterator();
//        while(it.hasNext())
//        {
//            Element ftpElement = (Element)it.next();
//          //獲取指定節點的值
//          System.out.println("ftp_name="+ftpElement.element("Name").getText());
//          System.out.println("ftp_name="+ftpElement.element("price").getText());
//          //獲取指定節點的屬性值
//          System.out.println("指定屬性的值:"+ftpElement.element("Name").attributeValue("new"));
////            System.out.println("ftp_name="+ftpElement.elementIterator("test"));
//        }
        

    }
    
    //第一种:根据属性来查找
    //结果为:<book id="2"><Name>Linux</Name><price>100</price></book>
    public void readXMLAttr() {
        String str = "<books><book id='1'><Name>Java</Name><price>100</price></book>";
        str = str
                + "<book id='2'><Name>Linux</Name><price>100</price></book></books>";
        // 生成一个Document
        Document document = null;
        try {
            document = DocumentHelper.parseText(str);
            Element book = (Element) document
                    .selectSingleNode("/books/book[@id='2']");
            System.out.println(book.asXML());
        } catch (DocumentException e) {
            e.printStackTrace();
        }
    }

    //第二种:根据节点名来查找
    //结果为:Java,Linux,
    public void readXMLElement() {
        String str = "<books><book id='1'><Name>Java</Name><price>100</price></book>";
        str = str
                + "<book id='2'><Name>Linux</Name><price>100</price></book></books>";
        Document document = null;
        try {
            document = DocumentHelper.parseText(str);
            List names = document.selectNodes("books/book/Name");// 记得这边是双斜杠且有区分大小写
            for (int i = 0; i < names.size(); i++) {
                System.out.print(((Element) names.get(i)).getText() + ",");
            }
        } catch (DocumentException e) {
            e.printStackTrace();
        }
    }

    //第三种:遍历整个XML取得属于指定类型节点的记录
    //结果为:1 Java 100
    //       2 Linux 100
    public void readXMLAllElement() {
//        String str = "<diffgr><NewDataSet><Table><UID>8613574286112</UID><Local_Number>86101756751060</Local_Number><Destination_Number>86123342545</Destination_Number><End_Time>2009-01-15T14:03:00+08:00</End_Time><Start_Time>2009-01-05T14:03:00+08:00</Start_Time><Opus>ADD</Opus><Amount>1</Amount></Table></NewDataSet></diffgr>";
        String str = "<books><book id='1'><Name>Java</Name><price>100</price></book>";
        str = str + "<book id='2'><Name>Linux</Name><price>100</price></book></books>";
        try {    
            Document document = null;
            document = DocumentHelper.parseText(str);
            Iterator it = document.getRootElement().elementIterator();
            Element element = null;
            while (it.hasNext()) {
                element = (Element) it.next();
                if (element.getName().equals("book")) {
                    System.out.print(element.attributeValue("id") + " ");
                    System.out.print(element.element("Name").getText() + " ");
                    System.out.println(element.element("price").getText());
                }
            }
        } catch (DocumentException e) {
            e.printStackTrace();
        }
    }

    //第四种:遍历所有属性
    //结果为:id:1
    //       name:Java
    //       price:120
    public void readXMLAllAttr() {
        String str = "<book id='1' name='Java' price='120'/>";
//        String str = "<Table><UID>8613574286112</UID><Local_Number>86101756751060</Local_Number><Destination_Number>86123342545</Destination_Number><End_Time>2009-01-15T14:03:00+08:00</End_Time><Start_Time>2009-01-05T14:03:00+08:00</Start_Time><Opus>ADD</Opus><Amount>1</Amount></Table>";
        Document document;
        try {
            document = DocumentHelper.parseText(str);             
          Iterator attributes = document.getRootElement().attributeIterator();
            while (attributes.hasNext()) {
                Attribute attribute = (Attribute) attributes.next();
                System.out.println(attribute.getName() + ":"
                        + attribute.getValue());
            }
        } catch (DocumentException e) {
            e.printStackTrace();
        }
    }

}

分享到:
评论
1 楼 xuganggogo 2010-07-19  
备注:调用该方法之前,应该先向工程中添加支持xpath的jar包,否则,会出现以下错误:

java.lang.NoClassDefFoundError: org/jaxen/JaxenException
at org.dom4j.DocumentFactory.createXPath(DocumentFactory.java:230)
at org.dom4j.tree.AbstractNode.createXPath(AbstractNode.java:207)
at org.dom4j.tree.AbstractNode.selectSingleNode(AbstractNode.java:183)
at xml_chb.dom4j_chb.getComplexInfofromDocument(dom4j_chb.java:82)
at xml_chb.dom4j_chb.main(dom4j_chb.java:92)
Exception in thread "main"

只需要引入jaxen包就行了,我使用的是hibernate包中的jaxen-1.1-beta-7.jar包。

相关推荐

    DOM4J jar包 xml解析 所有的dom4j-1.6.1 dom4j-2.0.2 dom4j-2.1.1包 导入直接使用

    在项目中使用DOM4J时,只需将相应的jar包(如dom4j-1.6.1.jar、dom4j-2.0.2.jar或dom4j-2.1.1.jar)导入到类路径中,即可开始利用其功能处理XML文档。导入后,可以按照DOM4J提供的API进行编程,快速实现XML的读写...

    dom4j dom4j dom4j dom4j

    DOM4J是一个强大的Java库,专门用于处理XML文档。它提供了灵活且高效的API,使得XML的解析、创建、修改和查询变得简单易行。在Java世界中,DOM4J是与DOM、SAX和JDOM等其他XML处理库并驾齐驱的一个选择,尤其在处理...

    dom4j_dom4j1.6.1安装包_

    DOM4J是一个强大的Java库,专门用于处理XML文档。它提供了灵活、高效的API,使得XML的解析、创建、查询和修改变得更为简单。在本文中,我们将深入探讨DOM4J 1.6.1版本的安装及其在Maven项目中的应用。 首先,DOM4J...

    dom4j-1.6.1 与 dom4j-2.0.0-ALPHA

    DOM4J是一个强大的Java库,专门用于处理XML文档。它提供了灵活、高效的API,使得XML的解析、创建、修改和查询变得简单。这次我们有两个版本的DOM4J库:1.6.1和2.0.0-ALPHA。这两个版本在功能、性能和API设计上都有所...

    dom4j_1.6.1.jar dom4j_2.1.0.jar

    标题提及的"dom4j_1.6.1.jar"和"dom4j_2.1.0.jar"是两个不同版本的DOM4J库的Java档案文件,DOM4J是一个非常流行的Java XML API,用于处理XML文档。这两个版本的差异在于功能、性能优化和可能存在的bug修复。描述中...

    dom4j-2.1.3.zip

    另一份重要的资源是"dom4j-2.1.3-sources.jar",它提供了DOM4J库的源代码,允许开发者深入研究DOM4J的内部实现,对于理解DOM4J的工作原理、进行扩展或者调试都是不可或缺的。通过阅读源代码,开发者可以学习到如何...

    dom4j dom4j1.6 dom4j最新版

    DOM4J是一个强大的Java库,专门用于处理XML文档。它提供了灵活且高效的API,使得XML的解析、创建、修改和查询变得简单。DOM4J 1.6是该库的一个较新版本,提供了完整的功能集以及对XML标准的广泛支持。 DOM4J的核心...

    dom4j-1.6.1.jar (dom4j) 欢迎下载

    dom4j-1.6.1.jar,Dom4j是一个Java的XML API接口,是jdom的进化版,dom4j基本用来读写xml文件,是一个十分优秀的JavaXML API接口

    dom4j-2.0.3.zip

    《深入解析DOM4J——基于Java的XML处理框架》 DOM4J,作为一个强大的Java XML API,是处理XML文档的主流工具之一。它提供了一套简单而高效的方式来操作XML文档,包括读取、写入、修改和遍历XML结构。在Java开发中,...

    所有版本的dom4j工具包

    标题提到的"所有版本的dom4j工具包"表明这是一个包含多版本DOM4J库的集合,可能包括了从早期到较新的一些版本,如dom4j-1.4.jar、dom4j-1.6.1.jar和dom4j-1.5.2.jar。这些不同版本的库可能分别对应于不同的功能特性...

    dom4j.jar 下载

    DOM4J是一个强大的Java库,专门用于处理XML文档。它是一个灵活且高性能的XML解析器,提供了丰富的API来创建、修改和操作XML数据。在Java应用程序中,DOM4J作为一个流行的选择,尤其在处理复杂的XML结构时,因为它...

    dom4j所依赖的所有jar包

    DOM4J是一个强大的Java库,专门用于处理XML文档。它提供了简单而直观的API,使得开发者可以方便地读取、写入、修改以及操作XML文件。DOM4J 1.6.1是这个库的一个稳定版本,发布于较早时期,但依然广泛应用于许多Java...

    dom4j-2.1.1-API文档-中英对照版.zip

    赠送jar包:dom4j-2.1.1.jar; 赠送原API文档:dom4j-2.1.1-javadoc.jar; 赠送源代码:dom4j-2.1.1-sources.jar; 赠送Maven依赖信息文件:dom4j-2.1.1.pom; 包含翻译后的API文档:dom4j-2.1.1-javadoc-API文档-...

    JavaEE源代码 dom4j-1.6.1

    JavaEE源代码 dom4j-1.6.1JavaEE源代码 dom4j-1.6.1JavaEE源代码 dom4j-1.6.1JavaEE源代码 dom4j-1.6.1JavaEE源代码 dom4j-1.6.1JavaEE源代码 dom4j-1.6.1JavaEE源代码 dom4j-1.6.1JavaEE源代码 dom4j-1.6.1JavaEE源...

    dom4j1.1-1.6.1.rar

    DOM4J是一个强大的Java库,专门用于处理XML文档。它提供了灵活且高效的API,使得XML的解析、创建、修改和查询变得简单。DOM4J的名字来源于“Document Object Model for Java”,但它并不仅仅是一个DOM实现,它还包含...

    org.dom4j.jar

    当我们遇到“java.lang.ClassNotFoundException: org.dom4j.DocumentException”的错误提示时,这通常意味着系统中缺少了DOM4j库,只需将“org.dom4j.jar”添加到项目类路径中即可解决此问题。 DOM4J是基于DOM和SAX...

    dom4j需要的包

    DOM4J是一个强大的Java库,专门用于处理XML文档。它提供了灵活且高效的API,使得XML的解析、创建、修改和查询变得简单。DOM4J的名字来源于“Document Object Model for Java”,它采用面向对象的设计思想,提供了...

    dom4j-2.1.1-API文档-中文版.zip

    赠送jar包:dom4j-2.1.1.jar; 赠送原API文档:dom4j-2.1.1-javadoc.jar; 赠送源代码:dom4j-2.1.1-sources.jar; 赠送Maven依赖信息文件:dom4j-2.1.1.pom; 包含翻译后的API文档:dom4j-2.1.1-javadoc-API文档-...

    dom4j 2.1.1

    DOM4J 2.1.1 是一个针对Java平台的高效、开源的XML处理库,其全称为“Document Object Model for Java”。这个库提供了一系列强大的API,使得开发人员能够轻松地解析、创建、修改和操作XML文档。XML(eXtensible ...

    DOM4J帮助文档及使用教程

    DOM4J是一个强大的Java库,专门用于处理XML文档。它提供了灵活、高性能的API,使得在Java应用程序中解析、创建、修改和操作XML文档变得容易。DOM4J因其易用性和丰富的功能集,在Java社区中广受欢迎,尤其在处理大型...

Global site tag (gtag.js) - Google Analytics