Element root = document.getRootElement();  
   
List   recordenvlist = document.selectNodes("//gml:envelope");     //gml:envelope

提示 NoClassDefFoundError org.dom4j.DocumentFactory.createXPath 原因:dom4j的xpath api依赖jaxen完成解决方法:在系统中加入jaxen.jar.jaxen.jar下载路径:http://jaxen.codehaus.org/releases.htmldom4j-1.6.1.jar下载路http://nchc.dl.sourceforge.net/sourceforge/dom4j/dom4j-1.6.1.jar

、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、

使用dom4j的xPath解析XML

一般的XML 
国外的dom4j已经很流行了,国内的相关资料相对较少,但普及风暴也即将到来。我们公司(老外开的)解析XML就是用的dom4j。 
今天公司没事做,自己也写一个小例子贴上来,嘻~~

  1. books.xml:
  2. <?xml version="1.0" encoding="UTF-8"?>
  3. <books>
  4. <!--This is a test for dom4j, jakoes, 2007.7.19-->
  5. <book show="yes" url="lucene.net">
  6. <title id="456">Lucene Studing</title>
  7. </book>
  8. <book show="yes" url="dom4j.com">
  9. <title id="123">Dom4j Tutorials</title>
  10. </book>
  11. <book show="no" url="spring.org">
  12. <title id="789">Spring in Action</title>
  13. </book>
  14. <owner>O'Reilly</owner>
  15. </books>

下面我们使用dom4j的xPath来解析:

  1. segment of ParseXML.java:
  2. public void parseBooks(){
  3. SAXReader reader = new SAXReader();
  4. try {
  5. Document doc = reader.read("books.xml");
  6. Node root = doc.selectSingleNode("/books");
  7. List list = root.selectNodes("book[@url='dom4j.com']");
  8. for(Object o:list){
  9. Element e = (Element) o;
  10. String show=e.attributeValue("show");
  11. System.out.println("show = " + show);
  12. }
  13. } catch (Exception e) {
  14. e.printStackTrace();
  15. }
  16. }

Document doc = reader.read("books.xml");的意思是加载XML文档,此是可以用doc.asXML()来查看,它将打印整个xml文档。

Node root = doc.selectSingleNode("/books");是读取刚才加载的xml文档内的books节点下的所有内容,对于本例也是整个xml文档。 
当然我们也可以加载/books下的某一个节点,如:book节点 
Node root = doc.selectSingleNode("/books/book"); 
或:Node root = doc.selectSingleNode("/books/*"); 
注意:如果有多个book节点,它只会读取第一个 
root.asXML()将打印: 
<book show="yes" url="lucene.net"> 
        <title id="456">Lucene Studing</title> 
</book>

既然加载了这么多,那我怎么精确的得到我想要的节点呢,别急,看下面: 
List list = root.selectNodes("book[@url='dom4j.com']"); 
它的意思就是读取books节点下的book节点,且book的节点的url属性为dom4j.com 
为什么使用list来接收呢,如果有两个book节点,且它们的url属性都为dom4j.com,此时就封闭到list里了。

如果想读取books下的所有book节点,可以这样: 
List list = root.selectNodes("book");

如果想读取books节点下的book节点下的title节点,可以这样: 
List list2 = root.selectNodes("book[@url='dom4j.com']/title[@id='123']");

注意:selectNodes()参数的格式: 
节点名[@属性名='属性值'],如:book[@url='dom4j.com'] 
如果有多个节点,用“/”分开,如:book[@url='dom4j.com']/title[@id='123']

最近就是读取封闭在List里的内容了,可以用Node来读取,也可以用Element来转换。 
attributeValue("属性")是读取该节点的属性值 
getText()是读取节点的的内容。 
                                              以上载自。。。。sorry不记得了 
要注意的是。在dom4j使用selectNodes等操作时要加上另一个包jaxen-1.1.1.jar 
带命名空间的XML 
在XML根节点出现<outputdatas xmlns="XML"> 
或<root xmlns="www.xxx.com"> xmlns等于的就是命名空间了 
因为dom4j不能识别带命名空间的节点,所以在读取带命名空间的XML时,要在每个节点前加上命名空间,方法如下例子:

  1. Map nsMap = null;
  2. @SuppressWarnings("unchecked")
  3. public void readXml(String xml) throws DocumentException{
  4. Document doc = DocumentHelper.parseText(xml);
  5. nsMap = new HashMap();
  6. String defaultNamespace = doc.getRootElement().getNamespaceURI();
  7. nsMap.put("default", defaultNamespace);
  8. //创建解析路径,就是在普通的解析路径前加上map里的key值
  9. XPath x = doc.createXPath("//default:outputdatas/default:results/"
  10. + "default:result[@set_id='201']"
  11. + "/default:row/default:col[@param_id='201001']");
  12. x.setNamespaceURIs(nsMap);
  13. List<Node> nodes = x.selectNodes(doc);
  14. Node node = x.selectSingleNode(doc);
  15. }

相信聪明的你。。一看就明白啦。。就不用注释啦

转自 http://lovell.iteye.com/blog/625662

带命名空间的XML的dom4j应用<转>的更多相关文章

  1. C#读取带命名空间的xml,xaml文件的解决方案

    使用C#读取xml文件有三种常用的方式: 1.xmlDocument 2.XmlTextReader 3.Linq To Xml 但是这些方式在读写有些带命名空间的xml时就不知道怎么办了(例如把xa ...

  2. 由“Jasperrpeorts 4.1.2升级到5.1.2对flex项目的解析”到AS3 带命名空间的XML的操作

    原文同步至:http://www.waylau.com/from-jasperrpeorts-4-1-2-upgraded-to-5-1-2-parsing-of-flex-projects-to-t ...

  3. dom4j解析带命名空间的xml文件

    文件内容如下 <ArrayOfString xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd=& ...

  4. C#读取带命名空间的xml

    首先带有命名空间的xml读取可以使用Xml.Linq,也可以使用xpath,本文将采用xpath的方式解析. 原文参考了:https://www.cnblogs.com/duanjt/p/544054 ...

  5. Linq to xml 操作带命名空间的xml

    昨天需要操作用代码操作csproj文件,实现不同vs版本的切换. 在用XElement读取了csproj文件以后怎么也获取不到想要的对象. 反反复复试验了好多次都不得要领:先看下csproj文件的内容 ...

  6. XML记一次带命名空间的xml读取

    public static void ReadXML(string xmlUrl) { //判断文件是否存在 if (!File.Exists(xmlUrl)) { Console.WriteLine ...

  7. linq检索带命名空间的xml

    XElement el = XElement.Load(fil); XNamespace ns = "http://schemas.microsoft.com/ado/2009/11/edm ...

  8. Linq to Xml读取复杂xml(带命名空间)

    前言:xml的操作方式有多种,但要论使用频繁程度,博主用得最多的还是Linq to xml的方式,觉得它使用起来很方便,就用那么几个方法就能完成简单xml的读写.之前做的一个项目有一个很变态的需求:C ...

  9. dom4j处理带命名空间的XML-使用XPath(转)

    dom4j处理带命名空间的XML-使用XPath 博客分类: XML   XPath 是一门在 XML 文档中查找信息的语言.XPath 可用来在 XML 文档中对元素和属性进行遍历. XPath 使 ...

随机推荐

  1. Java compiler level does not match解决方法(转)

    本文转自:https://www.cnblogs.com/lauer0246/p/5740572.html#undefined 从别的地方导入一个项目的时候,经常会遇到eclipse/Myeclips ...

  2. PHP5.3新特性

    1.首先对之前滥用的语法进行了规范 众所周知PHP在语言开发过程中有一个很好的容错性,导致在数组或全局变量中包含字符串不使用引号是可以不报错的,很多业余的开发者因为懒惰而产生的安全问题十分严重,之所以 ...

  3. VMware workstation 与 VMware GSX Server 的区别

    http://xsagaplus.iteye.com/blog/358917VMware是提供一套虚拟机解决方案的软件,主要产品分为如下三个. VMware-ESX-Server  这个版本并不需要操 ...

  4. C# -- 等待异步操作执行完成的方式 C# -- 使用委托 delegate 执行异步操作 JavaScript -- 原型:prototype的使用 DBHelper类连接数据库 MVC View中获取action、controller、area名称、参数

    C# -- 等待异步操作执行完成的方式 C# -- 等待异步操作执行完成的方式 1. 等待异步操作的完成,代码实现: class Program { static void Main(string[] ...

  5. centos7 搭建go环境

    下载go #cd /home #mkdir app #cd app #wget https://storage.googleapis.com/golang/go1.9.linux-amd64.tar. ...

  6. Android 判断SD卡是否存在及容量查询

    Android 判断SD卡是否存在及容量查询的简单方法如下: 首先要在AndroidManifest.xml中增加SD卡访问权限 <!-- 在SDCard中创建与删除文件权限 --> &l ...

  7. android自带theme

    在网上搜了一下,android自带theme如下: •android:theme="@android:style/Theme.Dialog"   将一个Activity显示为对话框 ...

  8. Shell习题100例

    每日一文件 https://github.com/aminglinux/shell100/blob/master/ 要求:安照这样的日期格式(xxxx-xx-xx)每日生成一个文件,如生成的文件为20 ...

  9. java web中请求和响应中包含中文出现乱码解析

    说明:在计算机中保存的一切文本信息是以一定的编码表(0,1,0,1)来保存我们所认识的字符(汉字或英文字符),由字符到计算机存储的二进制过程是编码,由读取二进制到文本的过程称为解码.而字符编码有多种不 ...

  10. js之正则表达式详解

    文章前提:会写几本的正则表达式,本文主要讲解js中关于正则方法的运用. (关于正则元字符可以查看http://www.php100.com/html/webkaifa/javascript/2010/ ...