`
lc52520
  • 浏览: 369040 次
  • 性别: Icon_minigender_1
  • 来自: 成都
社区版块
存档分类
最新评论

dom4j解析XML-2【Z】

    博客分类:
  • XML
阅读更多

要使用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
 
类开头引入:

  1. import  org.dom4j.io.SAXReader;   
  2. import  org.dom4j.Document;   
  3. import  org.dom4j.DocumentException;   
  4. import  org.dom4j.Element;   
  5. import  org.dom4j.Node;   
  6.   
  7. import  java.util.Iterator;   
  8. import  java.util.List;   
  9. import  java.io.*;   

 
以下是相关操作:
一.Document对象相关
1.读取XML文件,获得document对象.

  1. SAXReader reader =  new  SAXReader();   
  2. Document  document = reader.read( new  File( "input.xml" ));  

2.解析XML形式的文本,得到document对象.

  1. String text =  "<members></members>" ;   
  2. Document document = DocumentHelper.parseText(text);  

3.主动创建document对象.

  1. Document document = DocumentHelper.createDocument();   
  2. Element root = document.addElement( "members" ); // 创建根节点   

二.节点相关
1.获取文档的根节点.

  1. Element rootElm = document.getRootElement();  

2.取得某节点的单个子节点.

  1. Element memberElm=root.element( "member" ); // "member"是节点名   

3.取得节点的文字

  1. String text=memberElm.getText();  

也可以用:

  1. String text=root.elementText( "name" );这个是取得根节点下的name字节点的文字.  

4.取得某节点下名为"member"的所有字节点并进行遍历.

  1. List nodes = rootElm.elements( "member" );   
  2. for  (Iterator it = nodes.iterator(); it.hasNext();) {   
  3.    Element elm = (Element) it.next();   
  4.     // do something   
  5. }  

5.对某节点下的所有子节点进行遍历.

  1. for (Iterator it=root.elementIterator();it.hasNext();){   
  2.     Element element = (Element) it.next();   
  3.      // do something   
  4. }  

6.在某节点下添加子节点.

  1. Element ageElm = newMemberElm.addElement( "age" );  

7.设置节点文字.

  1. ageElm.setText( "29" );  

8.删除某节点.

  1. parentElm.remove(childElm); // childElm是待删除的节点,parentElm是其父节点   

获取一个Element之后可以进行的相关操作:

  1. attributue(String name) :获取元素String值。   
  2. elementIterator() :返回元素的所有子元素的Iterator迭代器。   
  3. elements() :返回元素包含所有子元素List。   
  4. getParent() :获取父元素Element。   
  5. getPath() :获取自己的xpath。   
  6. detach() :移除自己。   
  7. getName() :获取节点的名称。   
  8. selectNodes(String xpathExpression) :通过XPATH获取节点。   
  9. selectSingleNode(String xpathExpression) :通过XPATH获取一个节点。   
  10. getDocument() :作为一个Document返回。  

 

三.属性相关
1.取得某节点下的某属性

  1. Element root=document.getRootElement();      
  2. Attribute attribute=root.attribute( "size" ); // 属性名name   

2.取得属性的文字

  1. String text=attribute.getText();  

也可以用:

  1. String text2=root.element( "name" ).attributue( "firstname" );  

这个是取得根节点下name字节点的属性firstname的值.
 
3.遍历某节点的所有属性

  1. Element root=document.getRootElement();      
  2. for (Iterator it=root.attributeIterator();it.hasNext();){   
  3.     Attribute attribute = (Attribute) it.next();   
  4.     String text=attribute.getText();   
  5.     System.out.println(text);   
  6. }  

4.设置某节点的属性和文字.

  1. newMemberElm.addAttribute( "name" "sitinspring" );  

5.设置属性的文字

  1. Attribute attribute=root.attribute( "name" );   
  2. attribute.setText( "sitinspring" );  

6.删除某属性

  1. Attribute attribute=root.attribute( "size" ); // 属性名name   
  2. root.remove(attribute);  

 

四.将文档写入XML文件
1.文档中全为英文,不设置编码,直接写入的形式.

  1. XMLWriter writer =  new  XMLWriter( new  FileWriter( "output.xml" ));   
  2. writer.write(document);   
  3. writer.close();  

2.文档中含有中文,设置编码格式写入的形式.

  1. OutputFormat format = OutputFormat.createPrettyPrint();   
  2. format.setEncoding( "GBK" );     // 指定XML编码          
  3. XMLWriter writer =  new  XMLWriter( new  FileWriter( "output.xml" ),format);   
  4.   
  5. writer.write(document);   
  6. writer.close();  

 

五.字符串与XML的转换
1.将字符串转化为XML

  1. String text =  "<members> <member>sitinspring</member> </members>" ;   
  2. Document document = DocumentHelper.parseText(text);  

2.将文档或节点的XML转化为字符串.

  1. SAXReader  reader  =  new  SAXReader();   
  2. Document   document  =  reader .read(new File("input.xml"));              
  3. Element  root = document .getRootElement();                  
  4. String  docXmlText = document .asXML();   
  5. String  root rootXmlText =root.asXML();   
  6. Element  memberElm = root .element("member");   
  7. String  memberXmlText = memberElm .asXML();  

六.使用XPath快速找到节点
读取的XML文档示例

  1. <? xml   version = "1.0"   encoding = "UTF-8" ?>   
  2. < projectDescription >   
  3.    < name > MemberManagement </ name >   
  4.    < comment > </ comment >   
  5.    < projects >   
  6.      < project > PRJ1 </ project >   
  7.      < project > PRJ2 </ project >   
  8.      < project > PRJ3 </ project >   
  9.      < project > PRJ4 </ project >   
  10.    </ projects >   
  11.    < buildSpec >   
  12.      < buildCommand >   
  13.        < name > org.eclipse.jdt.core.javabuilder </ name >   
  14.        < arguments >   
  15.        </ arguments >   
  16.      </ buildCommand >   
  17.    </ buildSpec >   
  18.    < natures >   
  19.      < nature > org.eclipse.jdt.core.javanature </ nature >   
  20.    </ natures >   
  21. </ projectDescription >   


使用XPath快速找到节点project.

  1. public   static   void  main(String[] args){   
  2.    SAXReader reader =  new  SAXReader();   
  3.      
  4.     try {   
  5.      Document  doc = reader.read( new  File( "sample.xml" ));   
  6.      List projects=doc.selectNodes( "/projectDescription/projects/project" );   
  7.      Iterator it=projects.iterator();   
  8.       while (it.hasNext()){   
  9.        Element elm=(Element)it.next();         
  10.        System.out.println(elm.getText());   
  11.      }   
  12.        
  13.    }   
  14.     catch (Exception ex){   
  15.       ex.printStackTrace();   
  16.    }   
  17.  }
分享到:
评论

相关推荐

    dom4j-1.6.1.zip

    这个版本的DOM4J提供了一系列API,使得开发者能够方便地读取、写入、修改以及解析XML文件。下面我们将深入探讨DOM4J的核心功能和使用方法。 XML(eXtensible Markup Language)是一种标记语言,广泛用于数据交换、...

    dom4j-1.6jar

    《深入解析DOM4J-1.6:Java XML处理的核心库》 DOM4J-1.6是一款在Java环境中广泛使用的XML处理库,它提供了一种高效、灵活的方式来操作XML文档,包括读取、写入、修改以及遍历XML结构。DOM4J不仅实现了DOM API,还...

    xml-apis-1.4.01.zip

    "xml-apis-1.4.01.zip"是一个包含XML API实现的压缩包,其版本为1.4.01,主要用于处理和解析XML文档。 XML APIs(XML应用程序接口)是一组接口和类,提供了对XML文档进行操作的能力。这个压缩包中的核心组件是"xml-...

    xml文档解析器--c++源代码

    DOM解析会将整个XML文档加载到内存中形成一棵树状结构,方便遍历和操作;SAX是事件驱动的解析方式,只在遇到元素、属性等时触发回调函数,内存占用较低;而STL流式解析则介于两者之间,通过迭代器逐行读取XML,适合...

    xml-json.7z

    "xml-json.7z"这个压缩包文件包含了一个名为"xml-json.jar"的Java档案文件,暗示着它可能是一个Java库,用于在XML和JSON之间进行转换。 XML是一种结构化数据表示语言,它的设计目标是传输和存储数据,而不是显示...

    微信小程序解析xml的js

    4. **解析XML实例**: 假设我们有一个XML字符串`xmlString`,我们可以通过以下步骤解析它: - 导入库:`const DOMParser = require('./dom-parser.js');` - 创建DOMParser对象并解析XML:`const parser = new DOM...

    利用Java jdk(dom)解析和写入XML文件

    2. 使用`DocumentBuilder`解析XML文件,得到`Document`对象。这一步会构建XML文档的DOM树。 3. `Document`对象提供了访问XML元素的方法,如`getDocumentElement()`用于获取根元素,`getElementsByTagName()`用于查找...

    json2XMl.7z

    2. **创建XML文档**:一旦JSON解析为Java对象,可以使用Dom4j来创建对应的XML文档。首先,你需要创建一个`Document`对象,然后添加元素和属性。 ```java Document document = DocumentHelper.createDocument(); ...

    parserXML.7z

    此“parserXML.7z”压缩包可能包含一系列与解析XML相关的资源、代码示例或教程,帮助开发者了解如何在Android平台上处理XML数据。 XML解析在Android中的重要性在于,它允许应用程序从XML文件或网络服务中提取数据,...

    XStream XML解析

    XStream 相较于传统的基于 DOM、SAX 或 StAX 的 XML 解析方式,具有以下优势: - 更简洁的 API:不需要编写大量的 XML 映射代码。 - 自动处理对象关系:例如,对象的引用会正确地映射到 XML 的引用。 - 内存效率:...

    XML解析器 Xerces.7z

    7z压缩包中的"Xerces-2_11_0"很可能包含了Xerces的第2.11.0版本。此版本可能包含源代码、编译好的库文件、API文档、示例代码等资源,方便开发者在自己的项目中集成和使用Xerces。使用这些资源,开发者可以了解如何在...

    xml4wrapper_3.9.1.7z

    2. **xerces-c**:Apache软件基金会的产品,是一个高性能、跨平台的XML解析器,支持XML Schema、DOM、SAX等标准。 3. **tinyxml**:小巧且易于使用的C++库,适合轻量级的XML处理,对于嵌入式系统或资源有限的环境...

    Delphi 12 控件之DIXml v6.3.1 for Delphi 11-12 Athens + CRACK.7z

    - **XML解析**:DIXml能够快速解析XML文档,将其转换为内存中的数据结构,便于进一步处理。 - **XML生成**:对于需要创建XML文档的场景,DIXml提供API,使得生成XML文档变得简单易行。 - **XPath支持**:通过...

    JSDOM编程艺术代码.7z

    - JSON与DOM交互:将JSON数据解析并插入到DOM中,或从DOM中提取数据转换为JSON。 5. **目录结构分析** - `index.html`: 书中的主示例页面,展示了如何综合运用DOM编程技巧。 - `README.txt`: 可能包含了源码的...

    java解析zip文档,解决解析zip中解析xml和html文档流断的方法.pdf

    此外,注意在解析XML或HTML文件时选择合适的解析器,例如使用SAX或DOM解析XML,或者使用Jsoup等库解析HTML。这些解析器通常需要一个`InputStream`,你可以将`CustomInputStream`实例传递给它们。 总之,理解`...

    基于C++的xml文档解析器源代码

    解析XML时,我们需要定义类来表示XML元素、属性等,同时创建解析器类来读取XML文件。解析过程中,可能使用到的库有pugixml、TinyXML等,它们提供了API来简化XML处理。例如,pugixml库提供`pugi::xml_document`类来...

    xml存储留言方案php版-实现分页(源代码)

    `notes.php`可能会使用这些类来解析XML,提取所需数据。例如,使用DOMXPath查询所有留言: ```php $xml = new DOMDocument(); $xml-&gt;load('notes.xml'); $xpath = new DOMXPath($xml); $notes = $xpath-&gt;query('//...

    Android ReadXmlByPull 使用Pull解析Xml文件.rar

    2. **解析XML事件**:解析过程通过循环执行`next()`方法,该方法会返回当前事件的类型,如START_TAG、END_TAG、TEXT等。根据事件类型,我们可以执行相应的操作。 ```java int eventType = parser.getEventType(); ...

    hibernate必须用到的jar

    2. slf4j-api-x.y.z.jar 和 slf4j-simple-x.y.z.jar:SLF4J(Simple Logging Facade for Java)是一个日志门面,为各种日志框架提供一个简单的抽象层,如Log4j、java.util.logging、Logback等。slf4j-api是SLF4J的...

    Android XML解析

    在`Android解析XML文档.doc`中,可能包含了关于DOM解析的详细步骤和示例代码。 **SAX解析** SAX解析是基于事件驱动的,它不会一次性加载整个XML文档,而是逐行读取,当遇到特定的XML元素时触发相应的事件回调。这种...

Global site tag (gtag.js) - Google Analytics