1.重要语法:
SelectNodes("item") //从当前节点的儿子节点中选择名称为 item 的节点。
SelectNodes("/item") //从根节点的儿子节点中选择名称为 item 的节点。
SelectNodes("//item") //从任意位置的节点上选择名称为 item 的节点。要重点突出这个任意位置,它不受当前节点的影响,也就是说假如当前节点是在第 100 层(有点夸张),也可以选择第一层的名称为 item 的节点。
SelectNodes(".") //选择当前节点
SelectNodes("..") //选择当前节点的父节点。
SelectNodes("//item[@name]") //在 SelectNodes("//item") 的基础上,增加了一个限制,就是要求拥有 name 属性。
SelectNodes("//item[@name='111']") //在 SelectNodes("//item[@name]") 的基础上,增加了一个限制,就是要求 name 属性值为 111。注意语法中有引号;如果没有 引号,则表示是数字类型,对于数字类型可以使用大于号、小于号等,比如:SelectNodes("//item[@v>333]")。
SelectNodes("//item[1]") //选择第一个 item,注意是第一个,不是第二个。还有这里是指亲兄弟间的第一个 item,也就是说:父级若有三个 item,则选择第一个 ;若父级第二个 item 的有两个名称同样为 item 的儿子,则第一个儿子会被选择出来;若父级第三个 item 的也有两个名称同样为 item 的儿子,则第一个儿子也会被选择出来……
SelectNodes("//item[last()-1]") //倒数第二个节点,同样是指亲兄弟间的倒数第二个。
SelectNodes("//item[position()<=2]") //位置为第一和第二的节点(第一个节点的 position() 为 1),同样是指亲兄弟间的位置。
SelectNodes("//@name")
SelectNodes("/root/item/@name") //取 item 的 name 属性。选择 name 属性,注意这下选择的是属性,而不是节点了。用 Value 属性获取属性集合的属性值。
SelectNodes("/root/item") //根节点 root 下的 item 儿子节点。
SelectNodes("/root//item") //根节点 root 下的不管是儿子、孙子、重孙子……,只要是名称为 item 的统统选取出来。
2.通配符:
可用 * 表示任意节点名称,比如 SelectNodes("/channel/*/item");
用 @* 表示任意属性;
用 node() 表示任意类型的节点;
用 text() 表示文本类型的节点,实际上也就是表示取文本节点(元素节点下面是文本节点,文本节点下面才是文字)。
3.运算符:
| 表示或。SelectNodes("//item|//channel"),选择 item 或 channel 节点。
相关推荐
java 通过dom4j操作 xml,含范例和源码
使用dom4j读取xml四种方法,希望对各位朋友有所帮助
使用dom4j解析XML时,要快速获取某个节点的数据,使用XPath是个不错的方法,dom4j的快速手册里也建议使用这种方式 执行时却抛出以下异常: Exception in thread "main" java.lang.NoClassDefFoundError: org/jaxen...
} <br> /** 修改内容之三: 若title内容为Dom4j Tutorials,则删除该节点 */ <br> list = document.selectNodes("/books/book"); <br> iter = list.iterator(); <br> while(iter.hasNext()){ <br>...
dom4j解析包,没有源代码,二十字已到
Dom.documentElement.selectNodes("server/dir[text()='xx']") //选择server元素下的所有dir元素: Dom.documentElement.selectNodes("server/dir") //选择server元素下的第一个dir元素: Dom....
十三、前端基本功:DOM练习.rar
使用dom4j解析XML时,要快速获取某个节点的数据,使用XPath是个不错的方法,dom4j的快速手册里也建议使用这种方式 执行时却抛出以下异常: Exception in thread "main" java.lang.NoClassDefFoundError: org/jaxen...
使用dom4j解析XML时,要快速获取某个节点的数据,使用XPath是个不错的方法,dom4j的快速手册里也建议使用这种方式 执行时却抛出以下异常: Exception in thread "main" java.lang.NoClassDefFoundError: org/jaxen...
List itemList = doc.selectNodes("/ACCESOS/item/SOCIO"); //以上是dom4j+xpath的读取xml的写法
javascript中常用Dom方法. 写js时非常有用.
使用dom4j支持xpath的操作的几种主要形式 第一种形式 /a/b/c: 表示一层一层的,a下面 b下面的c 第二种形式 //b: 表示和这个名称相同,表示只要名称是b,都得到 第三种形式 /* : 所有...
NULL 博文链接:https://newtime.iteye.com/blog/437338
天在csdn上看到有人问 getElementsByTagName 和 selectNodes谁更快 ,这个还真没研究过。
4.DOM则为脚本和对象的交流提供一个公共平台,并将结果显示在浏览器窗口。 如果任何一个部分发生错误,都不会得到正确结果。 好了,看到这里,我们已经对XML是如何工作的有一个整体的大致的概念。通过这一章的...
现有代码中许多集合类对象取用时使用 (),IE 能接受,MF 不能。 (2)解决方法: 改用 [] 作为下标运算。如:document.forms("formName") 改为 document.forms["formName"]。 又如:document.getElementsByName("input...
xpath服务 为Hudson和Jelly(不再包含Jaxen)提供XPath和样式表功能。... 将与dom4j XPath相关的调用转换为XPath服务通常很简单,例如, doc.selectNodes(pathExpr) 变成 new XPath(pathExpr).selectNodes(doc)
JavaScript 兼容IE、FireFox、Chrome等浏览器的xml处理函数(xml同步/异步加载、xsl转换、selectSingleNode、selectNodes)
ASP 加数据库 四级菜单联动 <!--#include file="adoconn.asp"--> var m_oXMLDoc = new ActiveXObject("Microsoft.XMLDOM"); var m_sBaseSrc = "Tree.asp?ParentCode="; //源码爱好者(http://www.codefans.net) ...
XPath 被设计为供 XSLT、XQuery 以及 XPointer 使用。 教程 如需学习更多有关 XPath 的知识,请阅读我们的 XPath 教程。 如需学习更多有关 XQuery 的知识,请阅读我们的 XQuery 教程。 如需学习更多有关 XSLT 的...