微信怎么注册也会被盗吗

XPath入门教程整理_百度文库
两大类热门资源免费畅读
续费一年阅读会员,立省24元!
XPath入门教程整理
上传于|0|0|文档简介
&&绝对值得下载
阅读已结束,如果下载本文需要使用0下载券
想免费下载更多文档?
定制HR最喜欢的简历
下载文档到电脑,查找使用更方便
还剩15页未读,继续阅读
定制HR最喜欢的简历
你可能喜欢jquery中文基础入门_百度文库
两大类热门资源免费畅读
续费一年阅读会员,立省24元!
jquery中文基础入门
上传于|0|0|暂无简介
阅读已结束,如果下载本文需要使用1下载券
想免费下载本文?
定制HR最喜欢的简历
下载文档到电脑,查找使用更方便
还剩19页未读,继续阅读
定制HR最喜欢的简历
你可能喜欢[精]XPath入门教程
XPath 术语
节点(Node)
在 XPath 中,有七种类型的节点:元素、属性、文本、命名空间、处理指令、注释以及文档(根)节点。XML 文档是被作为节点树来对待的。树的根被称为文档节点或者根节点。
请看下面这个 XML 文档:
&?xml version="1.0" encoding="ISO-8859-1"?&
&bookstore&
& &title lang="en"&Harry Potter&/title&
& &author&J K. Rowling&/author&
& &year&2005&/year&
& &price&29.99&/price&
&/bookstore&
上面的XML文档中的节点例子:
&bookstore& (文档节点)
&author&J K. Rowling&/author& (元素节点)
lang="en" (属性节点)
基本值(或称原子值,Atomic value)
基本值是无父或无子的节点。
基本值的例子:
J K. Rowling
项目(Item)
项目是基本值或者节点。
父(Parent)
每个元素以及属性都有一个父。
在下面的例子中,book 元素是 title、author、year 以及 price 元素的父:
& &title&Harry Potter&/title&
& &author&J K. Rowling&/author&
& &year&2005&/year&
& &price&29.99&/price&
子(Children)
元素节点可有零个、一个或多个子。
在下面的例子中,title、author、year 以及 price 元素都是 book 元素的子:
& &title&Harry Potter&/title&
& &author&J K. Rowling&/author&
& &year&2005&/year&
& &price&29.99&/price&
同胞(Sibling)
拥有相同的父的节点
在下面的例子中,title、author、year 以及 price 元素都是同胞:
& &title&Harry Potter&/title&
& &author&J K. Rowling&/author&
& &year&2005&/year&
& &price&29.99&/price&
先辈(Ancestor)
某节点的父、父的父,等等。
在下面的例子中,title 元素的先辈是 book 元素和 bookstore 元素:
&bookstore&
& &title&Harry Potter&/title&
& &author&J K. Rowling&/author&
& &year&2005&/year&
& &price&29.99&/price&
&/bookstore&
后代(Descendant)
某个节点的子,子的子,等等。
在下面的例子中,bookstore的后代是 book、title、author、year 以及 price 元素:
&bookstore&
& &title&Harry Potter&/title&
& &author&J K. Rowling&/author&
& &year&2005&/year&
& &price&29.99&/price&
&/bookstore&
XML 实例文档
我们将在下面的例子中使用这个 XML 文档。
&?xml version="1.0" encoding="ISO-8859-1"?&
&bookstore&
& &title lang="eng"&Harry Potter&/title&
& &price&29.99&/price&
& &title lang="eng"&Learning XML&/title&
& &price&39.95&/price&
&/bookstore&
XPath 使用路径表达式在 XML 文档中选取节点。节点是通过沿着路径或者 step 来选取的。
下面列出了最有用的路径表达式:
选取此节点的所有子节点
从根节点选取
从匹配选择的当前节点选择文档中的节点,而不考虑它们的位置
选取当前节点
选取当前节点的父节点
在下面的表格中,我们已列出了一些路径表达式以及表达式的结果:
路径表达式
选取 bookstore 元素的所有子节点
/bookstore
选取根元素 bookstore
注释:假如路径起始于正斜杠( / ),则此路径始终代表到某元素的绝对路径!
bookstore/book
选取所有属于 bookstore 的子元素的 book 元素。
选取所有 book 子元素,而不管它们在文档中的位置。
bookstore//book
选择所有属于 bookstore 元素的后代的 book 元素,而不管它们位于 bookstore 之下的什么位置。
选取所有名为 lang 的属性。
谓语(Predicates)
谓语用来查找某个特定的节点或者包含某个指定的值的节点。
谓语被嵌在方括号中。
在下面的表格中,我们列出了带有谓语的一些路径表达式,以及表达式的结果:
路径表达式
/bookstore/book[1]
选取属于 bookstore 子元素的第一个 book 元素。
/bookstore/book[last()]
选取属于 bookstore 子元素的最后一个 book 元素。
/bookstore/book[last()-1]
选取属于 bookstore 子元素的倒数第二个 book 元素。
/bookstore/book[position()&3]
选取最前面的两个属于 bookstore 元素的子元素的 book 元素。
//title[@lang]
选取所有拥有名为 lang 的属性的 title 元素。
//title[@lang='eng']
选取所有 title 元素,且这些元素拥有值为 eng 的 lang 属性。
/bookstore/book[price&35.00]
选取所有 bookstore 元素的 book 元素,且其中的 price 元素的值须大于 35.00。
/bookstore/book[price&35.00]/title
选取所有 bookstore 元素中的 book 元素的 title 元素,且其中的 price 元素的值须大于 35.00。
选取未知节点
XPath 通配符可用来选取未知的 XML 元素。
匹配任何元素节点
匹配任何属性节点
匹配任何类型的节点
在下面的表格中,我们列出了一些路径表达式,以及这些表达式的结果:
路径表达式
/bookstore/*
选取 bookstore 元素的所有子节点
选取文档中的所有元素
//title[@*]
选取所有带有属性的 title 元素。
XML 实例文档
我们将在下面的例子中使用此 XML 文档:
&?xml version="1.0" encoding="ISO-8859-1"?&
&bookstore&
& &title lang="eng"&Harry Potter&/title&
& &price&29.99&/price&
& &title lang="eng"&Learning XML&/title&
& &price&39.95&/price&
&/bookstore&
轴可定义某个相对于当前节点的节点集。
选取当前节点的所有先辈(父、祖父等)
ancestor-or-self
选取当前节点的所有先辈(父、祖父等)以及当前节点本身
选取当前节点的所有属性
选取当前节点的所有子元素。
descendant
选取当前节点的所有后代元素(子、孙等)。
descendant-or-self
选取当前节点的所有后代元素(子、孙等)以及当前节点本身。
选取文档中当前节点的结束标签之后的所有节点。
选取当前节点的所有命名空间节点
选取当前节点的父节点。
选取文档中当前节点的开始标签之前的所有节点。
preceding-sibling
选取当前节点之前的所有同级节点。
选取当前节点。
XPath 运算符
下面列出了可用在 XPath 表达式中的运算符:
计算两个节点集
//book | //cd
返回所有带有 book 和 cd 元素的节点集
price=9.80
如果 price 是 9.80,则返回 true。
如果 price 是 9.90,则返回 false。
price!=9.80
如果 price 是 9.90,则返回 true。
如果 price 是 9.80,则返回 false。
price&9.80
如果 price 是 9.00,则返回 true。
如果 price 是 9.90,则返回 false。
小于或等于
price&=9.80
如果 price 是 9.00,则返回 true。
如果 price 是 9.90,则返回 false。
price&9.80
如果 price 是 9.90,则返回 true。
如果 price 是 9.80,则返回 false。
大于或等于
price&=9.80
如果 price 是 9.90,则返回 true。
如果 price 是 9.70,则返回 false。
price=9.80 or price=9.70
如果 price 是 9.80,则返回 true。
如果 price 是 9.50,则返回 false。
price&9.00 and price&9.90
如果 price 是 9.80,则返回 true。
如果 price 是 8.50,则返回 false。
计算除法的余数
XML实例文档
我们将在下面的例子中使用这个 XML 文档:
"books.xml" :
&?xml version="1.0" encoding="ISO-8859-1"?&
&bookstore&
&book category="COOKING"&
& &title lang="en"&Everyday Italian&/title&
& &author&Giada De Laurentiis&/author&
& &year&2005&/year&
& &price&30.00&/price&
&book category="CHILDREN"&
& &title lang="en"&Harry Potter&/title&
& &author&J K. Rowling&/author&
& &year&2005&/year&
& &price&29.99&/price&
&book category="WEB"&
& &title lang="en"&XQuery Kick Start&/title&
& &author&James McGovern&/author&
& &author&Per Bothner&/author&
& &author&Kurt Cagle&/author&
& &author&James Linn&/author&
& &author&Vaidyanathan Nagarajan&/author&
& &year&2003&/year&
& &price&49.99&/price&
&book category="WEB"&
& &title lang="en"&Learning XML&/title&
& &author&Erik T. Ray&/author&
& &year&2003&/year&
& &price&39.95&/price&
&/bookstore&
我们将使用微软的 XML DOM 对象来载入 XML 文档,并使用 selectNodes() 函数从 XML 文档选取节点:
set xmlDoc=CreateObject("Microsoft.XMLDOM")
xmlDoc.async="false"
xmlDoc.load("books.xml")
xmlDoc.selectNodes(路径表达式)
选取所有的 book 节点
下面的这个例子选取了 bookstore 元素下所有的 book 节点:
xmlDoc.selectNodes("/bookstore/book")
选取第一个 book 节点
下面的例子仅选取 bookstore 元素下第一个 book 节点:
xmlDoc.selectNodes("/bookstore/book[0]")
注释:IE 5 和 6 会把 [0] 作为第一个节点来执行,但是根据 W3C 的标准,应该使用 [1] !!
注释:这个问题在 IE 6 SP2 中被纠正了!
选取 price
下面的例子从所有的 price 节点选取文本:
xmlDoc.selectNodes("/bookstore/book/price/text()")
选取价格高于 35 的 price 价格
下面的例子会选取所有价格高于 35 的 price 节点:
xmlDoc.selectNodes("/bookstore/book[price&35]/price")
选取价格高于 35 的 title 节点
下面的例子会选取所有价格高于 35 的 title 节点:
xmlDoc.selectNodes("/bookstore/book[price&35]/title")
TA的最新馆藏

我要回帖

更多关于 微信莫名其妙被加好友 的文章

 

随机推荐