xpath定位元素元素的双斜杠是什么意思

君,已阅读到文档的结尾了呢~~
XPath中相对路径和绝对路径
扫扫二维码,随身浏览文档
手机或平板扫扫即可继续访问
XPath中相对路径和绝对路径
举报该文档为侵权文档。
举报该文档含有违规或不良信息。
反馈该文档无法正常浏览。
举报该文档为重复文档。
推荐理由:
将文档分享至:
分享完整地址
文档地址:
粘贴到BBS或博客
flash地址:
支持嵌入FLASH地址的网站使用
html代码:
&embed src='/DocinViewer-.swf' width='100%' height='600' type=application/x-shockwave-flash ALLOWFULLSCREEN='true' ALLOWSCRIPTACCESS='always'&&/embed&
450px*300px480px*400px650px*490px
支持嵌入HTML代码的网站使用
您的内容已经提交成功
您所提交的内容需要审核后才能发布,请您等待!
3秒自动关闭窗口XPath 教程
XPath 语法
XPath 使用路径表达式来选取 XML 文档中的节点或节点集。节点是通过沿着路径 (path) 或者步 (steps) 来选取的。
XML 实例文档
我们将在下面的例子中使用这个 XML 文档。
&?xml version="1.0" encoding="UTF-8"?&
&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 元素。
选取若干路径
通过在路径表达式中使用"|"运算符,您可以选取若干个路径。
在下面的表格中,我们列出了一些路径表达式,以及这些表达式的结果:
路径表达式
//book/title | //book/price
选取 book 元素的所有 title 和 price 元素。
//title | //price
选取文档中的所有 title 和 price 元素。
/bookstore/book/title | //price
选取属于 bookstore 元素的 book 元素的所有 title 元素,以及文档中所有的 price 元素。
记住登录状态
重复输入密码firefinder根据xpath或css寻找元素 | 易踪网HTML::TreeBuilder::XPath 来解析网页内容
作者为 扶 凯 于
3013 年 5 月 9 日更新: 不建议使用这个模块,使用 Mojo::Useragent 会方便多了。
强大的Perl中,有超级多强大的模块,让我们不在需要重复的发明轮子.下面这个就是一个强大的模块.HTML::TreeBuilder::XPath.它能象xml一样解析网站.怎么使用就不细讲了,如下,见实例,我是从网站得到我的网站排名的一个例子.会显示如下的结果
你的网站排名为: 199,954
HTML::TreeBuilder::XPath的实例
#!/usr/bin/perl
use LWP::S
use HTML::TreeBuilder::XP
use Data::D
my $url = &/siteinfo/www.&;
my $html = get( $url );
my $tree = new HTML::TreeBuilder::XP
$tree-&parse( $html );
my $items = $tree-&findnodes( '/html/body/descendant::div[@class[.=~/data down/]]' );
for my $item ( $items-&get_nodelist() ){
= $item-&content-&[1];
print &你的网站排名为:&.$srt.&\n&;
怎么使用最麻烦的一点在于这个XPath的语法.下面是简单的语法介绍.
下面列出了最有用的路径表达式:
选取此节点的所有子节点.
从根节点选取.
从匹配选择的当前节点选择文档中的节点,而不考虑它们的位置.
选取当前节点.
选取当前节点的父节点.
在下面的表格中,我们已列出了一些路径表达式以及表达式的结果:
路径表达式
选取 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 元素.
选取若干路径
通过在路径表达式中使用&|&运算符,您可以选取若干个路径.
在下面的表格中,我们列出了一些路径表达式,以及这些表达式的结果:
路径表达式
//book/title | //book/price
选取 book 元素的所有 title 和 price 元素.
//title | //price
选取文档中的所有 title 和 price 元素.
/bookstore/book/title | //price
选取属于 bookstore 元素的 book 元素的所有 title 元素,以及文档中所有的 price 元素.
XPATH的简单语法介绍
XPATH基本上是用一种类似目录树的方法来描述在XML文档中的路径.比如用&/&来作为上下层级间的分隔.第一个&/&表示文档的根节点(注意,不是指文档最外层的tag节点,而是指文档本身).比如对于一个HTML文件来说,最外层的节点应该是&/html&.
同样的,&..&和&.&分别被用来表示父节点和本节点.
XPATH返回的不一定就是唯一的节点,而是符合条件的所有节点.比如在HTML文档里使用&/html/head/scrpt&就会把head里的所有script节点都取出来.
为了缩小定位范围,往往还需要增加过滤条件.过滤的方法就是用&[&&]&把过滤条件加上.比如在HTML文档里使用&/html/body/div[@id='main']&,即可取出body里id为main的div节点.
其中@id表示属性id,类似的还可以使用如@name, @value, @href, @src, @class….
而函数text()的意思则是取得节点包含的文本.比如:&div&hello&p&world&/p&& /div&中,用&div[text()='hello']&即可取得这个div,而world则是p的text().
函数position()的意思是取得节点的位置.比如&li[position()=2]&表示取得第二个li节点,它也可以被省略为&li[2]&.
不过要注意的是数字定位和过滤条件的顺序.比如&ul/li[5][@name='hello']&表示取ul下第五项li,并且其name必须是hello,否则返回空.而如果用 &ul/li[@name='hello'][5]&的意思就不同,它表示寻找ul下第五个name为&hello&的li节点.
此外,&*&可以代替所有的节点名,比如用&/html/body/*/span&可以取出body下第二级的所有span,而不管它上一级是div还是p或是其它什么东东.
而 &descendant::&前缀可以指代任意多层的中间节点,它也可以被省略成一个&/&.比如在整个HTML文档中查找id为&leftmenu&的 div,可以用&/descendant::div[@id='leftmenu']&,也可以简单地使用& //div[@id='leftmenu']&.
至于&following-sibling::&前缀就如其名所说,表示同一层的下一个节点.&following-sibling::*&就是任意下一个节点,而&following-sibling::ul&就是下一个ul节点.
备注: 是我发现这个的最好的实现
转载请注明:作者为 扶 凯 于
在 http://www. 发表
如果发现内容有误请告知我, 我将及时更正。
文章总数:
评论总数:
页面总数:
分类总数:
标签总数:
网站已运行:XPath语法规则及实例_百度文库
两大类热门资源免费畅读
续费一年阅读会员,立省24元!
XPath语法规则及实例
阅读已结束,下载文档到电脑
想免费下载本文?
定制HR最喜欢的简历
下载文档到电脑,方便使用
还剩6页未读,继续阅读
定制HR最喜欢的简历
你可能喜欢}

我要回帖

更多关于 appium xpath定位元素 的文章

更多推荐

版权声明:文章内容来源于网络,版权归原作者所有,如有侵权请点击这里与我们联系,我们将及时删除。

点击添加站长微信