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();
}
}
}
分享到:
相关推荐
在项目中使用DOM4J时,只需将相应的jar包(如dom4j-1.6.1.jar、dom4j-2.0.2.jar或dom4j-2.1.1.jar)导入到类路径中,即可开始利用其功能处理XML文档。导入后,可以按照DOM4J提供的API进行编程,快速实现XML的读写...
DOM4J是一个强大的Java库,专门用于处理XML文档。它提供了灵活且高效的API,使得XML的解析、创建、修改和查询变得简单易行。在Java世界中,DOM4J是与DOM、SAX和JDOM等其他XML处理库并驾齐驱的一个选择,尤其在处理...
DOM4J是一个强大的Java库,专门用于处理XML文档。它提供了灵活、高效的API,使得XML的解析、创建、查询和修改变得更为简单。在本文中,我们将深入探讨DOM4J 1.6.1版本的安装及其在Maven项目中的应用。 首先,DOM4J...
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库的Java档案文件,DOM4J是一个非常流行的Java XML API,用于处理XML文档。这两个版本的差异在于功能、性能优化和可能存在的bug修复。描述中...
另一份重要的资源是"dom4j-2.1.3-sources.jar",它提供了DOM4J库的源代码,允许开发者深入研究DOM4J的内部实现,对于理解DOM4J的工作原理、进行扩展或者调试都是不可或缺的。通过阅读源代码,开发者可以学习到如何...
DOM4J是一个强大的Java库,专门用于处理XML文档。它提供了灵活且高效的API,使得XML的解析、创建、修改和查询变得简单。DOM4J 1.6是该库的一个较新版本,提供了完整的功能集以及对XML标准的广泛支持。 DOM4J的核心...
《深入解析DOM4J——基于Java的XML处理框架》 DOM4J,作为一个强大的Java XML API,是处理XML文档的主流工具之一。它提供了一套简单而高效的方式来操作XML文档,包括读取、写入、修改和遍历XML结构。在Java开发中,...
标题提到的"所有版本的dom4j工具包"表明这是一个包含多版本DOM4J库的集合,可能包括了从早期到较新的一些版本,如dom4j-1.4.jar、dom4j-1.6.1.jar和dom4j-1.5.2.jar。这些不同版本的库可能分别对应于不同的功能特性...
DOM4J是一个强大的Java库,专门用于处理XML文档。它提供了简单而直观的API,使得开发者可以方便地读取、写入、修改以及操作XML文件。DOM4J 1.6.1是这个库的一个稳定版本,发布于较早时期,但依然广泛应用于许多Java...
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源...
赠送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文档-...
当我们遇到“java.lang.ClassNotFoundException: org.dom4j.DocumentException”的错误提示时,这通常意味着系统中缺少了DOM4j库,只需将“org.dom4j.jar”添加到项目类路径中即可解决此问题。 DOM4J是基于DOM和SAX...
DOM4J是一个强大的Java库,专门用于处理XML文档。它提供了灵活且高效的API,使得XML的解析、创建、修改和查询变得简单。DOM4J的名字来源于“Document Object Model for Java”,它采用面向对象的设计思想,提供了...
赠送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 是一个针对Java平台的高效、开源的XML处理库,其全称为“Document Object Model for Java”。这个库提供了一系列强大的API,使得开发人员能够轻松地解析、创建、修改和操作XML文档。XML(eXtensible ...
DOM4J是一个强大的Java库,专门用于处理XML文档。它提供了灵活、高性能的API,使得在Java应用程序中解析、创建、修改和操作XML文档变得容易。DOM4J因其易用性和丰富的功能集,在Java社区中广受欢迎,尤其在处理大型...
DOM4J 的使用 DOM4J 是一个开源的 XML 解析包,由 dom4j.org 出品,应用于 Java 平台,采用了 Java 集合框架并完全支持 DOM、SAX 和 JAXP。DOM4J 的主要特点是使用大量的接口,所有主要接口都在 org.dom4j 里面定义...
DOM4J是一个强大的Java库,专门用于处理XML文档。它是一个灵活且高性能的XML解析器,提供了丰富的API来创建、修改和操作XML数据。在Java应用程序中,DOM4J作为一个流行的选择,尤其在处理复杂的XML结构时,因为它...