使用dom4j解析XML时,要快速获取某个节点的数据,使用XPath是个不错的方法,dom4j的快速手册里也建议使用这种方式,标题都写的这么阔气:Powerful Navigation with XPath,呵呵。
方法是使用Document的selectNodes(String XPath)方法,代码写法:
List l = doc.selectNodes("//COLS/COL1");
执行时却抛出以下异常:
Exception in thread "main" 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.selectNodes(AbstractNode.java:164)
这么好用的方法怎么能抛异常呢,一路跟踪过去看,竟然是“List l = doc.selectNodes("//COLS/COL1");”这句报错,查了一下才知道,不光要有dom4j这个包,还要有jaxen包:<jaxen-1.1-beta-6.jar>-238 KB,这应该是dom4j的基础包,在dom4j的zip包的lib目录里可以找到。即使用这个方法需要以下两个包:
dom4j-1.6.1.jar-306 KB
jaxen-1.1-beta-6.jar-238 KB
转自:http://ln831015.blog.163.com/blog/static/33339317200810185417681/
------------------------------------------------------------------------------------------
selectNodes
含义:给定的样式匹配应用于当前结点并返回匹配的结点集合
语法:pNode.selectNodes("pattern")
提示:pattern的编写与< xsl:for-each >的select属性的值类似,其中
以“/”开头表示从文档的根出发搜索;
以“//”开头表遍历文档的所有结点;
以“..”开头表示从当前结点的父结点开始;
如果欲从当前结点向下搜索则不能有以上特殊字符打头。