XPath 定位----光荣之路

XPath的绝对路径定位方式

被测试网页的HMTL代码

<html>
<body>
<div id="div1">
<input name="div1input"></input>
<a href="http://www.sogou.com">搜狗搜索</a>
<img alt="div1-img1" src="http://www.sogou.com/images/logo/new/sogou.png" href="http://www.sogou.com">搜狗图片</img>
<input type="button" value="查询"></>
</div>
<br>
<div name="div2">
<input name="div2input"></input>
<a href="http://www.baidu.com">百度搜索</a>
<img alt="div2-img2" src="http://www.baidu.com/img/bdlogo.png" href="http://www.baidu.com">百度图片</img>
</div>
</body>
</html>

绝对路径定位方式: 在被测试网页中,查找第一个 div 标签中的按钮。

XPath的表达式: /html/body/div/input[@value="查询"]

Java的定位语句: WebElement button= driver.findElement(By.xpath("/html/body/div/input[@value=‘查询‘]"));

XPath的相对路径定位方式

被测试网页的HMTL代码

<html>
<body>
<div id="div1">
<input name="div1input"></input>
<a href="http://www.sogou.com">搜狗搜索</a>
<img alt="div1-img1" src="http://www.sogou.com/images/logo/new/sogou.png" href="http://www.sogou.com">搜狗图片</img>
<input type="button" value="查询"></>
</div>
<br>
<div name="div2">
<input name="div2input"></input>
<a href="http://www.baidu.com">百度搜索</a>
<img alt="div2-img2" src="http://www.baidu.com/img/bdlogo.png" href="http://www.baidu.com">百度图片</img>
</div>
</body>
</html>

相对路径定位方式:
在被测试网页中,查找第一个 div 标签中的按钮。
XPath的表达式:
// input[@value="查询"]
Java的定位语句:
WebElement button= driver.findElement(By.xpath("//input[@value=‘查询‘]"));

XPath 使用索引号定位

被测试网页的HMTL代码

<html>
<body>
<div id="div1">
<input name="div1input"></input>
<a href="http://www.sogou.com">搜狗搜索</a>
<img alt="div1-img1" src="http://www.sogou.com/images/logo/new/sogou.png" href="http://www.sogou.com">搜狗图片</img>
<input type="button" value="查询"></>
</div>
<br>
<div name="div2">
<input name="div2input"></input>
<a href="http://www.baidu.com">百度搜索</a>
<img alt="div2-img2" src="http://www.baidu.com/img/bdlogo.png" href="http://www.baidu.com">百度图片</img>
</div>
</body>
</html>

使用索引号定位方式: 在被测试网页中,查找第二个 div 标签中的“查询”按钮。

XPath的表达式: //input[2]

Java的定位语句: WebElement button= driver.findElement(By.xpath("//input[2]"));

XPath 使用页面元素的属性值定位

被测试网页的HMTL代码

<html>
<body>
<div id="div1">
<input name="div1input"></input>
<a href="http://www.sogou.com">搜狗搜索</a>
<img alt="div1-img1" src="http://www.sogou.com/images/logo/new/sogou.png" href="http://www.sogou.com">搜狗图片</img>
<input type="button" value="查询"></>
</div>
<br>
<div name="div2">
<input name="div2input"></input>
<a href="http://www.baidu.com">百度搜索</a>
<img alt="div2-img2" src="http://www.baidu.com/img/bdlogo.png" href="http://www.baidu.com">百度图片</img>
</div>
</body>
</html>

使用页面属性值方式:
我们尝试定位被测试网页中的第一个图片元素。
XPath 的表达式
//img[@alt=‘div1-img1‘]
Java的定位语句:
WebElement img= driver.findElement(By.xpath("//img[@alt=‘div1-img1‘]"));

XPath 使用页面元素的属性值定位


预期定位的页面元素


定位表达式示例


使用的属性值


定位页面的第一个图片


//img[@href=‘http://www.sogou.com‘]


使用img标签的href属性值


定位第二个div中第一个Input输入框


//div[@name=‘div2‘]/input[@name=‘div2input‘]


使用div标签的name属性值

使用 input标签的name 属性值


定位第一个div中的第一个链接


//div[@id=‘div1‘]/a[@href=‘http://www.sogou.com‘]


使用的div标签的id 属性值

使用了a标签的href属性值


定位页面的查询按钮


//input[@type=‘button‘]


使用了type属性值

XPath 使用模糊页面属性值定位

被测试网页的HMTL代码

<html>
<body>
<div id="div1">
<input name="div1input"></input>
<a href="http://www.sogou.com">搜狗搜索</a>
<img alt="div1-img1" src="http://www.sogou.com/images/logo/new/sogou.png" href="http://www.sogou.com">搜狗图片</img>
<input type="button" value="查询"></>
</div>
<br>
<div name="div2">
<input name="div2input"></input>
<a href="http://www.baidu.com">百度搜索</a>
<img alt="div2-img2" src="http://www.baidu.com/img/bdlogo.png" href="http://www.baidu.com">百度图片</img>
</div>
</body>
</html>

XPath函数


定位表达式示例


表达式解释


Starts-with()


//img[starts-with(@alt,‘div1‘)]


查找图片alt属性开始位置包含’div1’关键字的页面元素


Contains()


//img[contains(@alt,‘g1‘)]


查找图片alt属性包含’g1’关键字的页面元素

使用 XPath 的轴(axis)进行元素定位

                                                             

XPath轴关键字


轴的含义说明


定位表达式示例


表达式解释


ancestor


选择当前节点上层的所有节点


//img[@alt=‘div2-img2‘]/ancestor::div


查找到alt属性值为div2-img的图片,并基于图片位置找到他上级的div页面元素


descendant


选择当前节点下层的所有节点


//div[@name=‘div2‘]/descendant::img


查找到name属性值的div页面元素,并基于div的位置找到他下级所有节点中的img页面元素


following


选择在当前节点之后显示的所有节点


//div[@id=‘div1‘]/following::img


超找到id 属性值为div1的div页面元素,并基于div的位置找到它后面节点中的img页面元素


following-sibling


选择当前节点的所有平级节点


//a[@href=‘http://www.sogou.com‘]/follo

wing-sibling::input


查找到链接地址为http://www.sogou.com的链接页面元素,并基于链接的位置找到它后续节点中input页面元素


preceding


选择当前节点前面的所有节点


//img[@alt=‘div2-img2‘]/preceding::div


查找到alt属性值为div2-img2的图片页面元素,并基于图片的位置找到它前面节点中的div页面元素


preceding-sibling


选择当前节点前面的所有同级节点


//img[@alt=‘div2-img2‘]/preceding-sibling

::a[1]


查找到alt属性值为div2-img2的图片页面元素,并基于图片的位置找到它前面同级节点中的第二个链接页面元素

XPath 使用页面元素的文本定位

被测试网页的HMTL代码

<html>
<body>
<div id="div1">
<input name="div1input"></input>
<a href="http://www.sogou.com">搜狗搜索</a>
<img alt="div1-img1" src="http://www.sogou.com/images/logo/new/sogou.png" href="http://www.sogou.com">搜狗图片</img>
<input type="button" value="查询"></>
</div>
<br>
<div name="div2">
<input name="div2input"></input>
<a href="http://www.baidu.com">百度搜索</a>
<img alt="div2-img2" src="http://www.baidu.com/img/bdlogo.png" href="http://www.baidu.com">百度图片</img>
</div>
</body>
</html>

使用text()函数可以定位到包含某些关键字的页面元素

XPath的表达式:

1) //a[text()=‘百度搜索‘]

2) //a[contains(text(),‘百度‘)]

3) //a[contains(text(),‘百度‘)]/preceding::div

Java 的定位语句:
?WebElement a=driver.findElement(By.xpath("//a[text()=‘百度搜索‘]"));
?WebElement a=driver.findElement(By.xpath("//a[contains(text(),‘百度‘)]"));
?WebElementdiv=driver.findElement(By.xpath("//a[contains(text(),‘百 度‘)]/preceding::div"));

时间: 2024-10-01 04:52:20

XPath 定位----光荣之路的相关文章

用XPath精确定位节点元素&amp;selenium使用Xpath定位之完整篇

在利用XSL进行转换的过程中,匹配的概念非常重要.在模板声明语句 xsl:template match = ""和模板应用语句xsl:apply-templates select = "" 中,用引号括起来的部分必须能够精确地定位节点.具体的定位方法则在XPath中给出. 之所以要在XSL中引入XPath的概念,目的就是为了在匹配XML文档结构树时能够准确地找到某一个节点元素.可以把XPath比作文件管理路 径:通过文件管理路径,可以按照一定的规则查找到所需要的文件

python selenium xpath定位时使用变量

driver.find_element_by_xpath(input[@id = "kw"]) 上面的代码,相信很多学习selenium + python 的朋友都很熟悉,就是定位百度首页搜索框的代码,如果我们想把"kw",用一个变量来表示该怎么操作呢? 目前,我知道的有两种方法,如下,是定位百度搜索框,点击搜索的代码,在XPath定位的过程中,用了变量: # encoding:utf-8 from selenium import webdriver import

appium的xpath定位

做自动化,元素定位是我们遇到的第一个困难.总是会有各种各样的问题,导致我们定位不到元素.前面一篇博客也写了元素定位的几种方法,今天主要分享一下xpath的定位方法. 这里我们仍然拿计算器举例. 比如我这里想去定位这个数字1的按钮. 首先打开UIuiautomatorviewer 我们鼠标点击一下数字7可以看到这个按钮的位置.我们上一篇中也说到了,在元素的属性中,class就是xpath的地址,我们是可以通过class来写xpath的. 那么这里我们就可以写成: find_element_by_x

java selenium (六) XPath 定位

什么是xpath xpath 是XML Path的简称, 由于HTML文档本身就是一个标准的XML页面,所以我们可以使用Xpath 的用法来定位页面元素. xpath定位的缺点 xpath 这种定位方式, webdriver会将整个页面的所有元素进行扫描以定位我们所需要的元素, 这是个非常费时的操作,  如果脚本中大量使用xpath做元素定位的话, 脚本的执行速度可能会稍慢 testXpath.html 代码如下 <html> <head><title>Test Xpa

selenium+python自动化之xpath定位

在上一篇简单的介绍了用工具查看目标元素的xpath地址,工具查看比较死板,不够灵活,有时候直接复制粘贴会定位不到.这个时候就需要自己手动的去写xpath了,这一篇详细讲解xpath的一些语法. 什么是xpath呢?官方介绍:XPath即为XML路径语言,它是一种用来确定XML(标准通用标记语言的子集)文档中某部分位置的语言.反正小编看这个介绍是云里雾里的,通俗一点讲就是通过元素的路径来查找到这个元素的,相当于通过定位一个对象的坐标,来找到这个对象. 一. xpath:属性定位 xptah也可以通

Selenium2+Python3.6实战(八):定位下拉菜单出错,如何解决?用select或xpath定位。

在登录界面,有时候会有几种不同的角色,针对不同角色定位到的信息是不一样的.查询资料知道定位下拉框的元素有两种方式:Xpath和select. 但是使用xpath定位时,user定位到了,登录的时候却是调用的administrator,很是费脑.几经周折,终于解决了. 1.关于user用户xpath定位:用selenium IDE录制了登录过程,查看代码才发现并没有定位到user上,而是直接输入密码登录的.这让我想到,user是默认的用户,当进入登录界面时,网页默认的用户就是user,所以可以省略

Xpath定位大全

selenium使用Xpath定位之完整篇 其中有一片文章提到了xpath元素定位,但是该文章中有些并不能适应一些特殊与个性化的场景.在文本中提供xpath元素的定位终极篇,你一定能在这里找到你需要的解决办法. 第一种方法:通过绝对路径做定位(相信大家不会使用这种方式) By.xpath("html/body/div/form/input") By.xpath("//input") 第三种方法:通过元素索引定位 By.xpath("//input[4]&q

Selenium-Python学习——通过XPath定位元素

用Xpath定位元素的方法总是记不住,经常要翻出各种文档链接参考,干脆把需要用到的内容整到这个笔记中方便查找. Xpath是在XML文档中定位节点的语言.使用 XPath 的主要原因之一是当想要查找的元素缺少合适的 id 或name属性.XPath定位器可以用来绝对或相对定位缺少id或name属性的元素,也可以是用其他属性进行定位. 通过XPath定位的元素容易受html调整的影响,可以先通过id或name属性找到就近的元素,如父元素,用以加强测试脚本的稳定性. 例如,源文件如下: <html>

selenium自学笔记---ecshop购买脚本 xpath定位元素(下拉框,单选框)

本机环境:xamppv3.2.1+ecshop3.0  1.元素定位写对,却一直报错,发现是页面元素加载的太慢,所以加上延时 from selenium import webdriverimport timedriver=webdriver.Chrome()driver.implicitly_wait(10) #自动延时10sdriver.get("http://localhost/ecshop")# driver.find_element_by_xpath('//div[@class