Selenium成长之路-11简单对象定位之XPATH方法

2023-11-03

XPath是一种在HTML文档中定位元素的语言。因为 HTML 可以看做 XML 的一种实现,所以 selenium 用 户可是使用这种强大语言在 web 应用中定位元素。

XPath基于XML的树状结构,提供在数据结构树中找寻节点的能力,XPath 很快的被开发者采用来当作小型查询语言。

XPath的使用,需要在Firefox浏览器先安装FireBug插件,建议使用Firefox浏览器(建议版本:57以前版本),因为57以后的版本,不支持FireBug插件了,也可能是新版本我个人使用的不太习惯。

安装完FireBug插件后,我们就在百度首页使用xpath进行元素定位

我们定位的是"百度一下"搜索按钮,在FirePath中可以看到,xpath的写法是://*[@id='su']  

如果我们定位的元素很长,怎么办呢?

如下图,我们要定位百度新闻页面的一段标题:

 

这样xpath路径直接写成:driver.find_element(By.XPATH,"//*[@id='pane-news']/div/ul/li[5]/strong/a")  是没有问题的

但是,在实际测试过程中,我们并不喜欢用这么长的路径来定位,这个时候,我们就可以使用contains()或者text()方法来定位;

contains()方法:driver.find_element(By.XPATH,"//*/a[contains(@href,'china.chinadaily')]")

text()方法:driver.find_element(By.XPATH,"//*[@class = 'lavalamp-item']/a[text()= '体育']")

这样就很简单了。

附上一段代码:

 

# coding = utf-8
from selenium import  webdriver
import time
from selenium.webdriver.common.by import By

driver = webdriver.Chrome()
url = 'http://news.baidu.com'
driver.get(url)

# 增加一个判断
try:
    #直接从firebug复制出来的路径
    # driver.find_element(By.XPATH,"//*[@id='pane-news']/div/ul/li[5]/strong/a")
    #使用contains()方法定位
    # driver.find_element(By.XPATH,"//*/a[contains(@href,'china.chinadaily')]")
    #使用text()方法定位
    driver.find_element(By.XPATH,"//*[@class='lavalamp-item']/a[text()='体育']")
    print("test pass")

except Exception as e:
    print("test failed",format(e))


time.sleep(5)
driver.quit()

 

总结一下Xpath的定位方法:

 

1.绝对路径定位:find_element_by_xpath("/html/body/div[2]/form/span/input")

2.相对路径定位:find_element_by_xpath("//input[@id=’input’]") #通过自身的 id 属性定位

3.布尔逻辑运算://div[@id='hd' or @name='q'] 

4.模糊定位(contains)://*/a[contains(@href,'china.chinadaily')]

5.再就是非常方便的,直接使用firebug,定位路径直接copy出来就可以了

xpath在实际的测试过程中运用很广泛,所以学习selenium的小伙伴,有必要掌握xpath的元素定位方法哦~~

 

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

Selenium成长之路-11简单对象定位之XPATH方法 的相关文章

  • 滑窗优化——边缘化

    文章目录 一 从高斯分布到信息矩阵 1 1 SLAM 问题概率建模 1 2 SLAM 问题求解 1 3 高斯分布和协方差矩阵 1 4 样例 1 4 1 样例1 1 4 2 样例2 二 舒尔补应用 边际概率 条件概率 2 1 舒尔补的概念 2
  • 2021年Android开发的前景如何?

    前言 安卓已死的论调已经出现很久了 随着去年裁员潮的出现 这种论调更加疯狂 现在的安卓生态 已经发展的非常好 但由于安卓原生开发的局限性 速度慢 无法跨平台 成本高 导致跨平台开发一直是资本家追逐的目标 这才导致RN Weex Flutte

随机推荐

  • SpringBoot配置logback-spring.xml日志

    在SpringBoot新建 logback spring xml 配置文件 因为SpringBoot官方是推荐这个方式 内容 拷贝复制下来就可以了
  • nvm1.1.10使用bug记录及低级解决方法

    意外发现nvm安装了node10 15 3版本后 并且切换到该版本后 会导致nvm其他版本切换失败 按照实训要求要使用vue2进行web应用开发 需安装node10 15 3版本 好吧 还好之前搞了nvm可以随意切换node版本 没关系 当
  • 怎样学好数据结构

    来源 我是码农 转载请保留出处和链接 本文链接 http www 54manong com id 6 1 数据结构学习思路 1 数据结构是计算机专业最重要最基础的一门课 对于有过编程经验的人 结合自己的编程体会去领悟它的思想 对于初学者 选
  • 关于java四舍五入时遇五不进位的问题

    在数据处理的过程中 碰到了保留小数点两位和四舍五入的问题 首先也是百度了网上的方法 double a DecimalFormat df new DecimalFormat df setRoundingMode RoundingMode HA
  • 吐血整理,Jenkins配置邮件发送测试报告持续集成,看这一篇就够了...

    目录 导读 前言 一 Python编程入门到精通 二 接口自动化项目实战 三 Web自动化项目实战 四 App自动化项目实战 五 一线大厂简历 六 测试开发DevOps体系 七 常用自动化测试工具 八 JMeter性能测试 九 总结 尾部小
  • caused by: java.lang.ClassNotFoundException: org.springframework.transaction.ReactiveTransactionMana

    SpringBoot启动时报错如下 Java包冲突问题解决 Dspring application admin enabled true javaagent C Program Files JetBrains IntelliJ IDEA 2
  • kafka学习笔记

    1 kafka是什么 kafka是一个高吞吐 分布式 基于发布 订阅的消息系统 最大的特性就是可以实时的处理大量的数据以满足各种需求场景 日志收集 离线和在线的消息消费 等等 2 kakfa的基础架构 topic 主题 kafka根据top
  • 数组和链表的区别

    数组是将元素在内存中连续存放 由于每个元素占用内存相同 可以通过下标迅速访问数组中任何元素 但是如果要在数组中增加一个元素 需要移动大量元素 在内存中空出一个元素的空间 然后将要增加的元素放在其中 同样的道理 如果想删除一个元素 同样需要移
  • 关于request.getinputStream读取一次的问题研究

    public int substract byte src int off int len throws IOException if end start 0 if in null return 1 重点 进行流读取标识 读到末尾 会返回
  • 只有技术人才能看懂的幽默

    面试官 请写出一段体现你水平的代码 我 sudo rm rf 面试官 这体现了你哪方面能力 我 我大学田径队的 1 程序有问题时不要担心 如果所有东西都没问题 你就失业了 2 计算机系的男同学追班里一女同学 结果此女总是躲躲闪闪 男的看没戏
  • swagger3.0访问后台地址

    swagger3 0访问后台地址 最近在学SpringBoot 其中swagger部分 发现后台地址不能访问了 当时导入的坐标为 这个是Gradle坐标 和Maven差不多 compile group io springfox name s
  • 计算机视觉基础7

    语义分割 从像素 pixel level 水平上 理解识别图片的内容 根据语义信息分割 输入 图片 输出 同尺寸的分割标记 每个像素会被识别为一个类别 FCN全卷积网络 所有层都是卷积层 相对位置保持不变 解决降采样后的低分辨率问题 全卷积
  • input类型

    下面通过设置input元素的type属性来演示不同类型的文本框的用法 效果图 当输入不正确的邮箱号 点击提交时 如下图 当输入不正确的网址 点击提交时 如下图 当输入不正确的手机号 点击提交时 如下图 代码如下
  • 不同的人每天工作有什么不同

    Author Skatexg Time 2020 07 17 不同的人每天工作有什么不同 有的人在为完成任务付出劳动 有的人在为有意义的成果付出劳动 为完成任务而付出的劳动是无意义的 只有产生成果的劳动才是有意义的 公司花钱买的是劳动成果
  • UPF learing2:set_level_shifter

    set level shifter 设置level shifter strategy在实现的过程中 level shifter name domain domain name elements list exclude elements l
  • python:10个小孩围成一圈分糖果

    10个小孩围成一圈分糖果 老师顺次分给每个人的糖果数为12 2 8 22 16 4 10 6 14 20 然后按以下规则调整 所有小孩同时把自己的糖果分一半给右边的小孩 糖果数如果变为奇数的人 再向老师补要一块 那多少次调整后 大家的糖果数
  • JavaScript——插入排序、堆排序

    一 插入排序 插入排序是一种简单直观的排序算法 它比冒泡排序 选择排序都更有效率 基本思路 插入排序的工作原理是通过构建有序序列 对于未排序元素 在已排序序列中从后向前扫描 找到对应的位置并插入 插入排序将数组分成 已排序 和 未排序 两部
  • 华为OD机试--路灯覆盖问题

    一条笔直的公路上安装了N个路灯 从位置0开始安装 路灯之间的距离是100m 每个路灯都有自己的照明半径 请计算第一个路灯和最后一个路灯之间 未照明区间的长度和 输入描述 第一行为一个数N 表示灯的个数 1 100000 第二行为N个空格分隔
  • 请问如何用nodejs通过post发送multipart/form-data类型的http请求?

    请问如何用nodejs通过post发送multipart form data类型的http请求 发布于 4 年前 作者 xuhaijinsky2008 24777 次浏览 请问如果用nodejs通过post发送multipart form
  • Selenium成长之路-11简单对象定位之XPATH方法

    XPath是一种在HTML文档中定位元素的语言 因为 HTML 可以看做 XML 的一种实现 所以 selenium 用 户可是使用这种强大语言在 web 应用中定位元素 XPath基于XML的树状结构 提供在数据结构树中找寻节点的能力 X