码迷,mamicode.com
首页 > 其他好文 > 详细

分享:selenium(一) xpath

时间:2018-08-24 16:05:55      阅读:167      评论:0      收藏:0      [点我收藏+]

标签:lin   @class   分享   F12   部分   front   举例   input   控制   

xpath无所不能定位。  

https://www.w3.org/TR/xpath/all/#axes  

 两个神器:firebug、xpath-checker

 

举例:混合定位

  //td[a//front[contains(text(),"从零开始视频")]//input[@type=‘checkbox‘]

确认xpath是否是正确的:firefox==>F12==>控制台==》$x(".//*[@id=‘su‘]")
 

 

 

 第一部分:基础定位:

1。依靠自己属性,文本定位(当f元素的文本text(),属性@是唯一时用)

//td[text()=‘wangm‘]   #文本是唯一的td元素

//div[contains(@class,‘cux-rightarrowicon-on‘)]    #class属性的值是唯一的div元素

//input[@type=‘radio‘ and @value=‘1‘]   #两个属性一起确定一个元素

 

2。依靠父节点定位(当子节点没有唯一可定位的属性,但它的父节点却有唯一的属性时用)

 //div[@class=‘wangm‘]/div

//div[@id=‘wangm‘]/div

// div[@id=‘testid‘]/input

 

 

3。 依靠子节点定位(当父节点没有唯一定位的属性,但它的子节点有确定的值或者有确定的组合时)   

//div[div[@id=‘wangm‘]]   #中括号是用来描述父子关系的。

//div[div[@name=‘wangm‘]] 

//div[p[@name=‘testp‘]] 

 

 

4。 混合型(实际应用中复杂些)

//div[div[@name=‘listType‘]]/img    #先用name属性找到子节点div,定位其父div,找的是父div下的img元素。

 

 

 

第二部分:进阶定位:

兄弟姐妹节点 

following-sibling   #后面的兄妹节点

preceding-sibling  #

 

starts-with  #以什么内容开头  语法与contains一样。

contains   #包含什么内容

not 

 

 

//input[@id=‘1234‘] /following-sibling::input   #后面的兄妹input节点

//input[@id=‘1234‘] /preceding-sibling::span   #前面的兄妹sapn 节点

//input[starts-with(@id,123‘)]   #以123开头的Id属性的内容的input元素。

//span[not(contains(text(),‘xpath‘))]   #寻找text内容不包含xpath的span元素。

 

 

 

补充整理:

绝对路径 :html/body/div/span[2]/input[4]   中间结构变化,就失效

相对路径: //开始  在整个html source里找,不管在什么位置

 

索 引:[x]     如://div/input[2]  #div下面第2个input

                   误解://span[28]   #一个页面上虽然有28个span,但只有放在同一个根节点下才是span[28]能定位到。

 

关键字:position:索引也可以认为是一个position

             last 

 

 

//div[@id=‘test‘]/span 

 

分享:selenium(一) xpath

标签:lin   @class   分享   F12   部分   front   举例   input   控制   

原文地址:https://www.cnblogs.com/yoyoma0355/p/9530006.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!