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

Selenium 选择器定位元素方式详解

1. 通过 ID 定位

  • 语法By.id(String id)
  • 特点
    • 最快速、最稳定的定位方式。
    • 元素的 id 属性必须唯一,且不能包含空格。
  • 示例
    <input type="text" id="username">
    
    from selenium import webdriver
    from selenium.webdriver.common.by import Bydriver = webdriver.Chrome()
    element = driver.find_element(By.ID, "username")
    

2. 通过 Name 定位

  • 语法By.name(String name)
  • 特点
    • 使用元素的 name 属性定位。
    • 如果有多个元素具有相同的 name,则返回第一个匹配的元素。
  • 示例
    <input type="text" name="username">
    
    element = driver.find_element(By.NAME, "username")
    

3. 通过 XPath 定位

  • 语法By.xpath(String xpath)
  • 特点
    • 使用 XPath 表达式定位元素。
    • XPath 是一种灵活且强大的定位方式,支持复杂的表达式。
    • 分为两种类型:
      • 绝对 XPath:从根节点开始定位(路径固定)。
      • 相对 XPath:从当前上下文节点开始定位。
  • 示例
    <div class="container"><input type="text" id="username">
    </div>
    
    # 相对 XPath:根据属性定位
    element = driver.find_element(By.XPATH, "//input[@id='username']")# 绝对 XPath(不推荐)
    element = driver.find_element(By.XPATH, "/html/body/div/input")
    

4. 通过 CSS Selector 定位

  • 语法By.cssSelector(String selector)
  • 特点
    • 使用 CSS 选择器定位元素。
    • 简洁、灵活,支持复杂的组合选择器(如层级关系、类名等)。
  • 示例
    <div class="container"><input type="text" id="username" class="form-control">
    </div>
    
    # 根据类名定位
    element = driver.find_element(By.CSS_SELECTOR, ".form-control")# 组合选择器:根据父元素的类名和子元素的 ID 定位
    element = driver.find_element(By.CSS_SELECTOR, "div.container input#username")
    

5. 通过 Link Text 定位

  • 语法By.linkText(String linkText)
  • 特点
    • 仅适用于 <a> 标签(超链接)。
    • 使用超链接的文本内容定位。
  • 示例
    <a href="https://www.example.com">Example</a>
    
    element = driver.find_element(By.LINK_TEXT, "Example")
    

6. 通过 Partial Link Text 定位

  • 语法By.partialLinkText(String linkText)
  • 特点
    • 同样适用于 <a> 标签。
    • 使用超链接文本的子串定位(支持模糊匹配)。
  • 示例
    <a href="https://www.example.com">Example Link</a>
    
    element = driver.find_element(By.PARTIAL_LINK_TEXT, "Exam")
    

7. 通过 Tag Name 定位

  • 语法By.tagName(String tagName)
  • 特点
    • 使用 HTML 标签名定位元素。
    • 如果有多个相同标签的元素,则返回第一个匹配的元素。
  • 示例
    <input type="text" id="username">
    
    elements = driver.find_elements(By.TAG_NAME, "input")
    

8. 通过 Class Name 定位

  • 语法By.className(String className)
  • 特点
    • 使用元素的 class 属性定位。
    • 如果有多个元素具有相同的类名,则返回第一个匹配的元素。
  • 示例
    <input type="text" class="form-control">
    
    element = driver.find_element(By.CLASS_NAME, "form-control")
    

9. 通过 Accessible Name 定位(可选)

  • 语法By.accessibilityId(String accessibilityId)
  • 特点
    • 主要用于移动端测试(如 Appium)。
    • 使用元素的无障碍访问名称定位。

10. 通过 Custom XPath/Selector(自定义方式)

  • 如果上述方式无法满足需求,可以通过自定义 XPath 或 CSS 选择器来实现复杂的定位逻辑。例如:
    # 根据父元素的属性和子元素的标签定位
    element = driver.find_element(By.XPATH, "//div[@class='container']/input")# 使用 contains() 方法匹配部分文本
    element = driver.find_element(By.XPATH, "//a[contains(text(), 'Exam')]")
    

选择合适的定位方式

在实际测试中,选择合适的定位方式非常重要。以下是一些选择建议:

  1. 如果元素有唯一的 id 属性,则优先使用 By.ID
  2. 如果没有 id,但有唯一的 name 属性,则使用 By.NAME
  3. 对于复杂的场景,可以使用 XPath 或 CSS Selector。
  4. 尽量避免使用 By.TAG_NAMEBy.CLASS_NAME,因为它们通常不够唯一。

总结

Selenium 提供了多种元素定位方式,每种方式都有其适用的场景和优缺点。在实际开发中,需要根据具体的 HTML 结构选择最合适的定位方式,以确保测试脚本的稳定性和可维护性。

希望这篇文章对你理解 Selenium 的元素定位方式有所帮助!

相关文章:

  • AI Agents系列之AI代理架构体系
  • ubuntu 22.04 使用ssh-keygen创建ssh互信账户
  • 基于Atlas 800I A2 + Ubuntu 22.04 LTS 离线部署神州鲲泰问学一体机平台
  • Axure PR 9 中继器 10 编辑行
  • HTTP 核心概念
  • Evidential Deep Learning和证据理论教材的区别(主要是概念)
  • 写论文时降AIGC和降重的一些注意事项
  • 1panel第三方应用商店(本地商店)配置和使用
  • 高防IP如何针对DDoS攻击特点起防护作用
  • 避免IP地址关联,多个手机设备的完美公网IP问题
  • 博客标题栏添加一个 About Me
  • MATLAB脚本实现了一个转子系统的参数扫描和分岔分析
  • Java学习手册:常见并发问题及解决方案
  • 首批人形机器人系列国家标准正式立项,我国人形机器人发展全方位提升
  • 基础知识-指针
  • uCOS3实时操作系统(系统架构和中断管理)
  • 系统架构设计师:计算机组成与体系结构(如CPU、存储系统、I/O系统)高效记忆要点、知识体系、考点详解、、练习题并提供答案与解析
  • 软考高级-系统架构设计师 论文范文参考(二)
  • kkFileView安装及使用
  • settimeout和setinterval区别
  • 泡泡玛特一季度整体收入同比增超1.6倍,海外收入增近5倍
  • 广西一季度GDP为6833.92亿元,同比增长5.8%
  • 外贸50城,谁在“扛大旗”?
  • “女孩被前男友泼汽油烧伤致残案”二审择期宣判
  • 俄乌就不打击民用基础设施释放对话信号
  • 马上评|京东VS美团,消费者希望看到的不是“口水仗”