软件测试/人工智能|详解selenium xpath定位

简介: 软件测试/人工智能|详解selenium xpath定位

在这里插入图片描述

在自动化测试中,使用Selenium定位网页元素是至关重要的。XPath是一种强大的定位方法,允许您通过元素的路径来精确定位,无论其在DOM(文档对象模型)中的位置如何。

selenium-xpath定位

element_xpath = driver.find_element(By.XPATH, 'xpath表达式')


xpath定位说明

xpath即为XML路径语言(XML Path Language),是由国际标准化组织W3C指定的,一种用来确定XML文档节点位置的语言


xpath定位优点

1.相较于其他定位方式,可支持更多定位方法,如:布尔逻辑判断、模糊定位等
2.可支持web定位、Android app原生页面定位


xpath定位缺点

1.需要从头到尾解析整个页面,速度较慢


xpath调试方法

方法1:在浏览器开发者模式的elements中,Ctrl+F搜索栏输入xpath表达式
方法2:在浏览器开发者模式的console中,按如下格式可验证表达式

$x("xpath表达式")   # 表达式中存在引号,则使用单引号,'$'可更换为'$$'


xpath节点

在xpath中,有七种类型的节点(node):元素、属性、文本、命名空间、处理指令、注释以及文档节点(或称为根节点)
在开始xpath语法前,我们需要简单了解这几种节点:
节点名称 | 说明 | 示例
:- | :- | :-
元素节点 | 网页中的各个标签 | 如\...\、\

...\


根节点 | 网页的第一个元素节点 | 网页的根节点通常为\...\
属性节点 | 标签中的各个属性 | 如\
...\
,id即为div节点的属性
文本节点 | 标签的文本 | 如\
啦啦啦\
,'啦啦啦'即为div节点的文本


xpath语法

xpath使用路径表达式描述目标节点与网页头的关系

绝对路径 & 相对路径

路径表达式有两种结构,分别为:

  • 绝对路径:从根节点/html开始往下,一层层的表示出来直到需要的节点为止。以百度输入框为例,表达式为:
    /html/body/div[1]/div[2]/div[5]/div[1]/div/form/span[1]
    
  • 相对路径:从任意节点开始,根据节点描述信息找到需要的节点。同样以百度输入框为例,表达式为:
    //input[@id='su']
    

对比两种表达式,可以发现:

  • 相对路径更简洁,方便阅读
  • 相对路径更稳定,当前端页面有结构变动就容易引起绝对路径发生变化
因此,在项目中几乎都是使用相对路径进行定位

xpath基本表达式

表达式 说明 示例 示例说明
nodename 选取此节点的所有子节点 html 选取\
根节点的所有子节点 /从根节点选取,或者用来选择子节点/html/body/textarea选择\中的所有\子节点</td> </tr> <tr> <td style="text-align:left">//</td> <td style="text-align:left">从匹配节点开始选取,或者选择后代节点</td> <td style="text-align:left">/html/body//textarea</td> <td style="text-align:left">选择\<body>中的所有\<textarea>后代节点</td> </tr> <tr> <td style="text-align:left">\</td> <td style="text-align:left"></td> <td style="text-align:left">选择多个节点</td> <td style="text-align:left">//div\</td> <td>//a</td> <td>选择所有\<div>节点和\<a>节点</td> </tr> <tr> <td style="text-align:left">..</td> <td style="text-align:left">选择当前节点的父节点</td> <td style="text-align:left">//p/..</td> <td style="text-align:left">选择所有\<p>的父节点</td> </tr> <tr> <td style="text-align:left">*</td> <td style="text-align:left">选择所有节点</td> <td style="text-align:left">/html/body/*</td> <td style="text-align:left">选择\<body>中的所有节点</td> </tr> </tbody> </table> <h2 id="xpath-">xpath谓语表达式</h2> <p>谓语表达式(predicate):紧跟在节点后面,嵌入在[]中的一段表达式,可用来筛选多个同名节点<br>谓语表达式作用原理:获取节点信息,通过表达式判断节点是否符合要求,为True则返回该节点<br>谓语格式:</p> <pre><code>节点名称[谓语] </code></pre><p><br></p> <table> <thead> <tr> <th style="text-align:left">常用谓语</th> <th style="text-align:left">说明</th> <th style="text-align:left">示例</th> <th style="text-align:left">示例说明</th> </tr> </thead> <tbody> <tr> <td style="text-align:left">n</td> <td style="text-align:left">节点编号</td> <td style="text-align:left">//div[2]</td> <td style="text-align:left">选择所有\<div>节点且<font color='red'>该节点是其父级的第二个\<div>节点</font></td> </tr> <tr> <td style="text-align:left">last()</td> <td style="text-align:left">最后一个节点</td> <td style="text-align:left">//div[last()]</td> <td style="text-align:left">选择所有\<div>节点且<font color='red'>该节点是其父级的最后一个子节点</font></td> </tr> <tr> <td style="text-align:left">position()</td> <td style="text-align:left">比较节点编号</td> <td style="text-align:left">//div[position() < 3]</td> <td style="text-align:left">选择所有\<div>节点且<font color='red'>该节点是其父级的前两个\<div>节点</font></td> </tr> <tr> <td style="text-align:left">@属性</td> <td style="text-align:left">属性</td> <td style="text-align:left">//input[@id]</td> <td style="text-align:left">选择所有\<input>节点且该节点带id属性</td> </tr> <tr> <td style="text-align:left">@属性='属性值'</td> <td style="text-align:left">比较属性</td> <td style="text-align:left">//input[@id='kw']</td> <td style="text-align:left">选择所有\<input>节点且该节点id属性为'kw'</td> </tr> <tr> <td style="text-align:left">text()</td> <td style="text-align:left">比较节点文本</td> <td style="text-align:left">//a[text()='新闻']</td> <td style="text-align:left">选择所有\<a>节点且该节点文本为'新闻'</td> </tr> </tbody> </table> <p><br></p> <table> <thead> <tr> <th style="text-align:left">谓语运算符</th> <th style="text-align:left">说明</th> <th style="text-align:left">示例</th> <th style="text-align:left">示例说明</th> </tr> </thead> <tbody> <tr> <td style="text-align:left">= != <br> > < <br> >= <=</td> <td style="text-align:left">大小比较</td> <td style="text-align:left">/html/body/div[position()=2]</td> <td style="text-align:left">选择\<body>中的第2个\<div>子节点</td> </tr> <tr> <td style="text-align:left">+ - *、<br> div mod</td> <td style="text-align:left">加减乘除求余</td> <td style="text-align:left">/html/body/div[last()-1]</td> <td style="text-align:left">选择\<body>中的倒数第2个\<div>子节点</td> </tr> <tr> <td style="text-align:left">and or not()</td> <td style="text-align:left">或、且、非运算</td> <td style="text-align:left">//*[@id='kw' and @class='s_ipt']</td> <td style="text-align:left">选择所有id='kw'并且class='s_ipt'的节点</td> </tr> <tr> <td style="text-align:left">contains()</td> <td style="text-align:left">包含</td> <td style="text-align:left">//*[contains(text(), '新闻')]</td> <td style="text-align:left">选择所有文本带有'新闻'二字的节点</td> </tr> <tr> <td style="text-align:left">starts-with()</td> <td style="text-align:left">头部包含</td> <td style="text-align:left">//*[starts-with(@id, 's')]</td> <td style="text-align:left">选择所有文本以'新闻'开头的节点</td> </tr> </tbody> </table> <p>备注:</p> <ol> <li>last()、position()、text()、not()这类带有括号的表达式,实质都是xpath提供的函数,本篇文章只列出了常用函数</li> <li>根据W3C标准,第一个节点编号应该是[1],但在IE5及更高版本中第一个节点编号是[0]</li> </ol> <h2 id="xpath-axis-">xpath轴(axis)</h2> <p>轴:表示所选节点与当前节点之间的树关系,用来筛选对于当前节点有相同关系的一类节点<br>轴格式:</p> <pre><code>当前节点/轴名称::节点名称 </code></pre><table> <thead> <tr> <th style="text-align:left">轴</th> <th style="text-align:left">说明</th> <th style="text-align:left">示例</th> <th style="text-align:left">示例说明</th> </tr> </thead> <tbody> <tr> <td style="text-align:left">ancestor</td> <td style="text-align:left">先辈节点</td> <td style="text-align:left">//input[@id='kw']/ancestor::\ *</td> <td style="text-align:left">选择id='kw'的\<input>节点的所有先辈节点</td> </tr> <tr> <td style="text-align:left">ancestor-or-self</td> <td style="text-align:left">先辈节点以及当前节点</td> <td style="text-align:left">略</td> <td style="text-align:left">略</td> </tr> <tr> <td style="text-align:left">attribute</td> <td style="text-align:left">节点属性</td> <td style="text-align:left">略</td> <td style="text-align:left">略</td> </tr> <tr> <td style="text-align:left">child</td> <td style="text-align:left">子节点,等同于/</td> <td style="text-align:left">/html/body/child::div</td> <td style="text-align:left">选择\<body>中的所有\<div>子节点</td> </tr> <tr> <td style="text-align:left">descendant</td> <td style="text-align:left">后代节点,等同于//</td> <td style="text-align:left">/html/body/descendant::div</td> <td style="text-align:left">选择\<body>中的所有\<div>后代节点</td> </tr> <tr> <td style="text-align:left">descendant-or-self</td> <td style="text-align:left">后代节点以及当前节点</td> <td style="text-align:left">略</td> <td style="text-align:left">略</td> </tr> <tr> <td style="text-align:left">following</td> <td style="text-align:left">结束标签之后的所有节点</td> <td style="text-align:left">略</td> <td style="text-align:left">略</td> </tr> <tr> <td style="text-align:left">namespace</td> <td style="text-align:left">命名空间</td> <td style="text-align:left">略</td> <td style="text-align:left">略</td> </tr> <tr> <td style="text-align:left">parent</td> <td style="text-align:left">父节点</td> <td style="text-align:left">略</td> <td style="text-align:left">略</td> </tr> <tr> <td style="text-align:left">preceding</td> <td style="text-align:left">开始标签之前的所有节点</td> <td style="text-align:left">略</td> <td style="text-align:left">略</td> </tr> <tr> <td style="text-align:left">preceding-sibling</td> <td style="text-align:left">当前节点之前的所有同级节点</td> <td style="text-align:left">略</td> <td style="text-align:left">略</td> </tr> <tr> <td style="text-align:left">self</td> <td style="text-align:left">当前节点</td> <td style="text-align:left">略</td> <td style="text-align:left">略</td> </tr> </tbody> </table> <h3 id="-">总结</h3> <p>XPath是一个强大的工具,但也需要谨慎使用,因为Xpath方法查找元素较慢,一般情况下优先选择是其他定位方法,希望本文能够帮到大家!</p>
相关文章
|
23天前
|
XML 前端开发 Java
《手把手教你》系列技巧篇(十四)-java+ selenium自动化测试-元素定位大法之By xpath上卷(详细教程)
【4月更文挑战第6天】按宏哥计划,本文继续介绍WebDriver关于元素定位大法,这篇介绍定位倒数二个方法:By xpath。xpath 的定位方法, 非常强大。使用这种方法几乎可以定位到页面上的任意元素。xpath 是XML Path的简称, 由于HTML文档本身就是一个标准的XML页面,所以我们可以使用Xpath 的用法来定位页面元素。XPath 是XML 和Path的缩写,主要用于xml文档中选择文档中节点。基于XML树状文档结构,XPath语言可以用在整棵树中寻找指定的节点。
47 0
|
4天前
|
Web App开发 IDE 测试技术
深入理解自动化测试框架Selenium的设计与实践
【4月更文挑战第27天】在软件开发周期中,确保代码质量和功能正确性至关重要。随着敏捷开发的普及和持续集成/持续部署(CI/CD)的实践,自动化测试已成为现代开发工作流程的核心部分。本文将探讨一个广泛使用的开源自动化测试工具——Selenium,并剖析其设计原理、架构以及在实际中的应用。我们将通过具体案例分析,展示如何有效利用Selenium进行跨浏览器测试,并讨论在真实环境中可能遇到的挑战及解决方案。
|
6天前
|
数据采集 前端开发 测试技术
《手把手教你》系列技巧篇(三十一)-java+ selenium自动化测试- Actions的相关操作-番外篇(详解教程)
【4月更文挑战第23天】本文介绍了网页中的滑动验证码的实现原理和自动化测试方法。作者首先提到了网站的反爬虫机制,并表示在本地创建一个没有该机制的网页,然后使用谷歌浏览器进行验证。接着,文章详细讲解了如何使用WebElement的click()方法以及Action类提供的API来模拟鼠标的各种操作,如右击、双击、悬停和拖动。
9 2
|
6天前
|
Java 测试技术 持续交付
深入理解与应用Selenium WebDriver进行自动化测试
【4月更文挑战第25天】 在现代软件开发过程中,自动化测试已成为确保产品质量和加速市场发布的关键步骤。Selenium WebDriver作为业界广泛采用的自动化测试工具之一,提供了一种灵活且高效的方式来模拟用户与Web应用程序交互。本文将探讨Selenium WebDriver的核心概念、架构以及实际应用中的技巧和最佳实践。通过深入分析其工作原理及常见问题解决方案,旨在帮助测试工程师提升测试效率,确保测试结果的准确性和可靠性。
|
7天前
|
Web App开发 数据采集 Java
《手把手教你》系列技巧篇(三十)-java+ selenium自动化测试- Actions的相关操作下篇(详解教程)
【4月更文挑战第22天】本文介绍了在测试过程中可能会用到的两个功能:Actions类中的拖拽操作和划取字段操作。拖拽操作包括基本讲解、项目实战、代码设计和参考代码,涉及到鼠标按住元素并将其拖动到另一个元素上或指定位置。划取字段操作则介绍了如何在一段文字中随机选取一部分,包括项目实战、代码设计和参考代码。此外,文章还提到了滑动验证的实现,并提供了相关的代码示例。
33 2
|
9天前
|
前端开发 测试技术 C++
Python自动化测试面试:unittest、pytest与Selenium详解
【4月更文挑战第19天】本文聚焦Python自动化测试面试,重点讨论unittest、pytest和Selenium三大框架。unittest涉及断言、TestSuite和覆盖率报告;易错点包括测试代码冗余和异常处理。pytest涵盖fixtures、参数化测试和插件系统,要注意避免过度依赖unittest特性。Selenium的核心是WebDriver操作、等待策略和测试报告生成,强调智能等待和元素定位策略。掌握这些关键点将有助于提升面试表现。
22 0
|
11天前
|
Web App开发 JavaScript 前端开发
深入理解自动化测试框架Selenium的设计与实现
【4月更文挑战第20天】 在软件测试领域,自动化测试已成为提升测试效率和确保产品质量的关键手段。Selenium作为一款广泛使用的开源自动化测试框架,其设计精巧且功能强大,为Web应用提供了一种灵活、高效的测试解决方案。本文将深入探讨Selenium的核心架构与实现细节,解析其如何通过模拟用户操作来执行测试用例,以及它如何适应不断变化的Web技术标准。通过对Selenium内部机制的剖析,旨在帮助测试工程师更好地掌握该工具,并在测试实践中发挥其最大效能。
|
12天前
|
前端开发 JavaScript Java
《手把手教你》系列技巧篇(二十五)-java+ selenium自动化测试-FluentWait(详细教程)
【4月更文挑战第17天】其实今天介绍也讲解的也是一种等待的方法,有些童鞋或者小伙伴们会问宏哥,这也是一种等待方法,为什么不在上一篇文章中竹筒倒豆子一股脑的全部说完,反而又在这里单独写了一篇。那是因为这个比较重要,所以宏哥专门为她量身定制了一篇。FluentWait是Selenium中功能强大的一种等待方式,翻译成中文是流畅等待的意思。在介绍FluentWait之前,我们来讨论下为什么需要设置等待,我们前面介绍了隐式等待和显式等待。
35 3
|
14天前
|
Java 测试技术 定位技术
《手把手教你》系列技巧篇(二十三)-java+ selenium自动化测试-webdriver处理浏览器多窗口切换下卷(详细教程)
【4月更文挑战第15天】本文介绍了如何使用Selenium进行浏览器窗口切换以操作不同页面元素。首先,获取浏览器窗口句柄有两种方法:获取所有窗口句柄的集合和获取当前窗口句柄。然后,通过`switchTo().window()`方法切换到目标窗口句柄。在项目实战部分,给出了一个示例,展示了在百度首页、新闻页面和地图页面之间切换并输入文字的操作。最后,文章还探讨了在某些情况下可能出现的问题,并提供了一个简单的本地HTML页面示例来演示窗口切换的正确操作。
42 0
|
15天前
|
敏捷开发 监控 前端开发
深入理解自动化测试框架Selenium的架构与实践
【4月更文挑战第16天】 在现代软件开发过程中,自动化测试已成为确保产品质量和加快迭代速度的关键手段。Selenium作为一种广泛使用的自动化测试工具,其开源、跨平台的特性使得它成为业界的首选之一。本文旨在剖析Selenium的核心架构,并结合实际案例探讨其在复杂Web应用测试中的高效实践方法。通过详细解读Selenium组件间的交互机制以及如何优化测试脚本,我们希望为读者提供深入理解Selenium并有效运用于日常测试工作的参考。

热门文章

最新文章