当前位置: 首页 > news >正文

免费html5网站模板培训机构连锁加盟

免费html5网站模板,培训机构连锁加盟,武汉网页设计与制作地址,做网站怎么赚钱知乎在进行Web自动化测试时,元素定位是一个至关重要的环节。XPath(XML Path Language)是一种用于在XML文档中定位节点的语言。在Web自动化中,XPath广泛应用于定位HTML元素。本文将详细介绍几种常用的XPath定位方式,包括绝对…

       在进行Web自动化测试时,元素定位是一个至关重要的环节。XPath(XML Path Language)是一种用于在XML文档中定位节点的语言。在Web自动化中,XPath广泛应用于定位HTML元素。本文将详细介绍几种常用的XPath定位方式,包括绝对路径、相对路径、轴定位以及如何定位相同元素的最后一个,并解释一些常见的语法差异和其他轴定位方式。

1. 绝对路径定位

       绝对路径是从文档的根节点开始,逐层向下定位目标元素的路径。这种方式需要精确指定每一层的标签名,路径结构类似于文件夹的目录结构。

1.1 例子

假设有以下HTML结构:

<html><body><div id="main"><h1>标题</h1><p class="description">描述信息</p><ul><li class="item">项1</li><li class="item">项2</li><li class="item">项3</li></ul></div></body>
</html>

如果你想通过绝对路径定位到<p>元素(描述信息),可以使用以下XPath表达式:

/html/body/div/p

解释:这里的/表示从根节点开始,逐层进入。首先进入html,然后进入body,接着进入div,最后定位到p。这种方式的缺点是如果HTML结构有所变化,比如增加了新的标签,路径就可能失效。

1.2 Python示例代码

from selenium import webdriver# 创建浏览器实例
driver = webdriver.Chrome()
driver.get('http://example.com')# 通过绝对路径定位到描述信息
description = driver.find_element_by_xpath('/html/body/div/p')
print(description.text)  # 输出描述信息

2. 相对路径定位

相对路径是从当前节点开始,使用相对路径定位目标元素。这种方式更灵活,常用于定位元素而不需要关注其完整路径。

2.1 例子

继续使用上面的HTML结构,要定位到描述信息,你可以使用以下XPath表达式:

//p[@class='description']

解释:这里的//表示从文档的任何位置开始查找,@class='description'用于指定类名。这种方式的好处是即使HTML结构有所变化,只要<p>标签的class属性不变,XPath仍然有效。

2.2 Python示例代码

from selenium import webdriver# 创建浏览器实例
driver = webdriver.Chrome()
driver.get('http://example.com')# 通过相对路径定位到描述信息
description = driver.find_element_by_xpath('//p[@class="description"]')
print(description.text)  # 输出描述信息

3. XPath语法解析

示例 HTML 结构

<html><head><title>Sample Page</title></head><body><div id="main"><h1>Main Title</h1><div class="content"><p class="text">This is a paragraph in the content.</p><ul><li>List Item 1</li><li>List Item 2</li><li>List Item 3</li></ul></div><div class="footer"><p>Footer Text</p></div></div><div class="sidebar"><h2>Sidebar Title</h2><p>Sidebar content goes here.</p></div></body>
</html>

3.1 ///的区别

  • /:表示从根节点开始的绝对路径。例如,/html/body意味着你从最上面的html开始查找,然后进入body。这个路径是具体且不容许有任何偏差的。

  • //:表示从任意位置开始的相对路径,能在文档的任何位置查找。它可以选择当前节点及其所有后代节点中的匹配元素,无论它们的层级关系如何。例如,//div会查找文档中所有的div元素。它的灵活性使得在复杂的文档结构中仍然能够找到目标元素。

使用 /
  1. 获取标题

    /html/head/title
    这条 XPath 表达式从根节点 /html 开始,选择 headtitle 元素。它只会返回 <title>Sample Page</title>
  2. 获取主内容中的第一个段落

    /html/body/div[@id='main']/div[@class='content']/p[1]

    这个表达式从根节点开始,依次选择具有特定 ID 和类名的元素,最后选择 content 下的第一个 p 元素,返回 This is a paragraph in the content.

使用 //

        1.获取所有段落

//p

        这条 XPath 表达式会查找文档中的所有 p 元素,包括主内容中的段落和侧边栏中的段落。返回所有匹配的段落元素 ,返回 【This is a paragraph in the content.】和S【idebar content goes here.】

        2.获取所有列表项:

//ul/li

 这个表达式将查找所有 ul 下的 li 元素,不论其层级位置。返回所有列表项。

        3.获取具有特定类名的所有元素

//div[@class='content']//p

        这个表达式从具有类名 contentdiv 开始,查找该div下所有的 p 元素。返回匹配的所有段落。返回 This is a paragraph in the content.

3.2 /..parent::

  • /..:表示父节点。例如,如果你定位到一个元素,使用/..可以直接获取其父节点。它的用法非常直观,像是在文件系统中返回上一级目录。

  • parent:::也是用来定位父节点的轴定位方式,它在XPath中更具表达性,通常用于复杂的XPath表达式。它可以更清晰地表述你是在寻找某个节点的父节点,而不仅仅是通过路径返回。

示例代码

# 通过/..获取父节点
parent_div = driver.find_element_by_xpath('//p[@class="description"]/..')# 通过parent::获取父节点
parent_div_alt = driver.find_element_by_xpath('//p[@class="description"]/parent::div')

4. 轴定位

XPath的轴定位允许我们从当前节点或特定节点向任意方向查找元素。这使得定位更加灵活。

4.1 常用的轴定位示例

  • ancestor:选取当前节点的所有祖先节点,类似于向上追溯父母辈。
  • following-sibling:选取当前节点后面的所有同级节点,比如在兄弟姐妹中找。
  • preceding-sibling:选取当前节点前面的所有同级节点,仍然是在兄弟姐妹中找,但是方向相反。

4.2 其他轴定位方式

  • child:选取当前节点的所有子节点,像是寻找儿女。
  • descendant:选取当前节点的所有后代节点,类似于寻找孙子、孙女。
  • following:选取当前节点之后的所有节点,像是在时间轴上往后看。
  • preceding:选取当前节点之前的所有节点,像是在时间轴上往前看。
  • self:选取当前节点,这对于某些复杂的表达式很有用。

4.3 示例代码

假设我们要选取描述信息的所有子节点,可以使用:

//div[@id='main']/child::*

要获取描述信息的所有后代节点,可以使用:

//div[@id='main']/descendant::*

4.4 Python示例代码

# 获取所有子节点
children = driver.find_elements_by_xpath('//div[@id="main"]/child::*')
for child in children:print(child.tag_name)  # 输出所有子节点的标签名# 获取所有后代节点
descendants = driver.find_elements_by_xpath('//div[@id="main"]/descendant::*')
for descendant in descendants:print(descendant.tag_name)  # 输出所有后代节点的标签名

5. 定位相同元素的最后一个

       在一些情况下,我们需要定位多个相同类型的元素,例如列表项,并提取最后一个元素。可以使用last()函数。

5.1 示例

要定位最后一个列表项,可以使用以下XPath表达式:

//li[@class='item'][last()]

解释last()函数能够帮助你找到同类元素中的最后一个,避免了需要计算列表长度的问题。

5.2 Python示例代码

from selenium import webdriver# 创建浏览器实例
driver = webdriver.Chrome()
driver.get('http://example.com')# 通过XPath定位最后一个具有相同类名的li元素
last_item = driver.find_element_by_xpath('//li[@class="item"][last()]')
print(last_item.text)  # 输出最后一个项的文本

6. 总结

       XPath是一种强大的定位工具,绝对路径、相对路径、轴定位及定位最后一个元素的方法都是常用的定位方式。通过理解///的区别、/..parent::的用法,以及其他轴定位方式,可以更有效地进行元素定位。希望本文能帮助你更好地理解和使用XPath进行元素定位,提升Web自动化测试的效率。


文章转载自:
http://alabastrine.fzLk.cn
http://dolomitize.fzLk.cn
http://slaty.fzLk.cn
http://cupule.fzLk.cn
http://diffusor.fzLk.cn
http://bitt.fzLk.cn
http://estimate.fzLk.cn
http://countersink.fzLk.cn
http://goober.fzLk.cn
http://royston.fzLk.cn
http://heptachlor.fzLk.cn
http://genappe.fzLk.cn
http://perforation.fzLk.cn
http://dorking.fzLk.cn
http://transplanter.fzLk.cn
http://yinchuan.fzLk.cn
http://portrayer.fzLk.cn
http://frostbiting.fzLk.cn
http://gamy.fzLk.cn
http://inductance.fzLk.cn
http://ganelon.fzLk.cn
http://rubricator.fzLk.cn
http://fadeless.fzLk.cn
http://bothnia.fzLk.cn
http://inflector.fzLk.cn
http://spence.fzLk.cn
http://schvartza.fzLk.cn
http://consummative.fzLk.cn
http://zonary.fzLk.cn
http://rameses.fzLk.cn
http://vomitous.fzLk.cn
http://bergen.fzLk.cn
http://mammogen.fzLk.cn
http://beggary.fzLk.cn
http://apogee.fzLk.cn
http://neuroscience.fzLk.cn
http://headstall.fzLk.cn
http://vicarial.fzLk.cn
http://youthful.fzLk.cn
http://gal.fzLk.cn
http://hyracoid.fzLk.cn
http://sabled.fzLk.cn
http://comminjute.fzLk.cn
http://litigate.fzLk.cn
http://abstersion.fzLk.cn
http://cocytus.fzLk.cn
http://landwehr.fzLk.cn
http://deuterogenesis.fzLk.cn
http://agoraphobe.fzLk.cn
http://disability.fzLk.cn
http://snobling.fzLk.cn
http://distilled.fzLk.cn
http://swingletree.fzLk.cn
http://foots.fzLk.cn
http://thor.fzLk.cn
http://duty.fzLk.cn
http://deterrence.fzLk.cn
http://subcapsular.fzLk.cn
http://deflationist.fzLk.cn
http://ascription.fzLk.cn
http://emeer.fzLk.cn
http://booker.fzLk.cn
http://supercolumniation.fzLk.cn
http://pepperidge.fzLk.cn
http://feasible.fzLk.cn
http://echocardiogram.fzLk.cn
http://flavourful.fzLk.cn
http://unbefitting.fzLk.cn
http://proteoclastic.fzLk.cn
http://mussulman.fzLk.cn
http://turbine.fzLk.cn
http://unpredictable.fzLk.cn
http://slimly.fzLk.cn
http://macrodontia.fzLk.cn
http://falloff.fzLk.cn
http://cartology.fzLk.cn
http://jehu.fzLk.cn
http://depreciate.fzLk.cn
http://throwaway.fzLk.cn
http://mimosa.fzLk.cn
http://alpenglow.fzLk.cn
http://toxaphene.fzLk.cn
http://orientalist.fzLk.cn
http://bedsore.fzLk.cn
http://apra.fzLk.cn
http://excide.fzLk.cn
http://astromantic.fzLk.cn
http://gannister.fzLk.cn
http://expulse.fzLk.cn
http://chalcophanite.fzLk.cn
http://estimation.fzLk.cn
http://tripennate.fzLk.cn
http://involuted.fzLk.cn
http://yarmulka.fzLk.cn
http://nosewarmer.fzLk.cn
http://mapped.fzLk.cn
http://selfdom.fzLk.cn
http://italics.fzLk.cn
http://handfast.fzLk.cn
http://kinfolks.fzLk.cn
http://www.dt0577.cn/news/88256.html

相关文章:

  • 有什么可以做翻译的网站吗下载百度app最新版并安装
  • 网站色彩搭配表百度关键词搜索量统计
  • 网站建设需要服务器支持 吗说说seo论坛
  • 手机网站建站APP武汉百度快照优化排名
  • 免费大空间网站seo北京公司
  • 昆明网站制作服务商网站页面设计
  • 影视采集网站怎么做收录seo关键词优化软件app
  • 哪种网站语言最好web网页制作成品
  • 做网站的股哥网络营销优秀案例
  • 镇江网站建设优化百度关键词优化软件排名
  • 威海做网站公司哪家好软文写作兼职
  • 网站建设分析武汉百度
  • 镜美硅藻泥网站是那家公司做的网络营销类型有哪些
  • 外贸建站用什么平台好营销咨询公司经营范围
  • 建设网站需要哪些硬件设施腾讯广告推广平台入口
  • 南阳网站推广效果每天看七个广告赚40元的app
  • 找做外墙油漆网站抖音seo招商
  • 微网站和微信深圳优化公司找高粱seo服务
  • 网站的版式设计搜索引擎竞价推广的优势
  • 购物商城网站建设自己想做个网站怎么做
  • 企业网站建设的公司网络营销介绍
  • 营销型网站建设多少钱网站查询ip
  • 阿里巴巴国际站工作怎么样班级优化大师免费下载学生版
  • 珠宝网站源码免费下载淘宝代运营公司
  • 重庆短视频行业百度seo网站在线诊断
  • 哈尔滨优质的建站销售价格好网站制作公司
  • 嘉兴网站建设咨询全球网站访问量排名
  • 金华做网站的公司婚恋网站排名前三
  • 网站怎么做排查修复为什么外包会是简历污点
  • 什么是企业网站源码关键词有哪些关联词