UI自动化框架之Selenium八大元素定位(二)

UI自动化框架之Selenium八大元素定位(二)

  • 一、Selenium八大元素定位方式
    • [1.1 ID定位](#1.1 ID定位)
    • [1.2 name定位](#1.2 name定位)
    • [1.3 Class Name定位](#1.3 Class Name定位)
    • [1.4 Tag Name定位](#1.4 Tag Name定位)
    • [1.5 Link Text定位](#1.5 Link Text定位)
    • [1.6 Partial Link Text定位](#1.6 Partial Link Text定位)
    • [1.7 CSS Selector定位](#1.7 CSS Selector定位)
    • [1.8 XPath定位](#1.8 XPath定位)
    • [1.9 元素定位总结](#1.9 元素定位总结)

一、Selenium八大元素定位方式

在Selenium WebDriver中,有八大常用的定位方式,可以帮助我们在网页中快速准确地定位和操作。

1.1 ID定位

通过元素的ID属性来定位,这是一种最快的定位方式。

python 复制代码
from selenium import webdriver 
from selenium.webdriver.common.by import By

driver = webdriver.Chrome()

driver.get("https://www.baidu.com/")

ele = driver.find_element(By.ID,'chat-submit-button')

1.2 name定位

通过元素的name属性来定位。

python 复制代码
from selenium import webdriver 
from selenium.webdriver.common.by import By

driver = webdriver.Chrome()

driver.get("https://www.baidu.com/")

ele = driver.find_element(By.NAME,'name')

1.3 Class Name定位

通过元素的class属性来定位,如果一个元素有对个类,可以使用.class1.class2的形式。

python 复制代码
from selenium import webdriver 
from selenium.webdriver.common.by import By

driver = webdriver.Chrome()

driver.get("https://www.baidu.com/")

ele = driver.find_element(By.CLASS_NAME,'chat-input-scroll-style')

ele = driver.find_element(By.CLASS_NAME,'.chat-input-textarea.chat-input-scroll-style')

1.4 Tag Name定位

通过元素的html标签名来定位,如p,div,span等。同类型标签很多,定位不唯一,一般会结合其他定位方式一起使用。

html 复制代码
<p>这是一段html</p>
<ul>
<li><a href="#">这是一个a链接<a></li>
<li><a href="#">这是一个a链接<a></li>
<li><a href="#">这是一个a链接<a></li>
<li><a href="#">这是一个a链接<a></li>
<ul>
python 复制代码
from selenium import webdriver 
from selenium.webdriver.common.by import By

driver = webdriver.Chrome()

driver.get("https://www.baidu.com/")

# 获取第一个a链接
ele = driver.find_element(By.TAG_NAME,'a')

# 获取所有a链接
ele = driver.find_elements(By.TAG_NAME,'a')

通过元素的链接文本标签来定位。只能用于链接元素,且文本需要完全匹配

python 复制代码
from selenium import webdriver 
from selenium.webdriver.common.by import By

driver = webdriver.Chrome()

driver.get("https://www.baidu.com/")

ele = driver.find_element(By.LINK,'首页')

通过元素的链接文本的一部分来定位标签,这在链接文本很长时非常有用。

python 复制代码
from selenium import webdriver 
from selenium.webdriver.common.by import By

driver = webdriver.Chrome()

driver.get("https://www.baidu.com/")

ele = driver.find_element(By.PARTIAL,'这个是我的书签')

1.7 CSS Selector定位

通过CSS选择器来定位元素。可组合各种条件查找

python 复制代码
from selenium import webdriver 
from selenium.webdriver.common.by import By

driver = webdriver.Chrome()

driver.get("https://www.baidu.com/")

ele = driver.find_element(By.CSS_SELECTOR,'span.check_name')

1.8 XPath定位

通过XPath表达式来定位。是一种强大的定位方式,可以实现任何复杂的定位需求。但语法稍微复杂,性能相对较慢,当其他定位方式都无法正确找到元素时,可以使用该方式。

绝对路径不推荐使用。

python 复制代码
from selenium import webdriver 
from selenium.webdriver.common.by import By

driver = webdriver.Chrome()

driver.get("https://www.baidu.com/")

# // 指的是相对路径,从匹配选择的当前节点选择文档中的节点,而不考虑它们的位置
# 通配符*表示未知的元素, //* 定位所有元素
# 属性定位 [@属性名称="属性值"] @id是通过ID来定位,@class是通过class定位,@name通过name来定位
ele = driver.find_element(By.XPATH,'//*[@id="chat-textarea"]')

拓展

XPath轴定位

语法:轴名称::标签名

轴名称 描述
ancestor 选取当前节点的祖先节点
parent 选取当前节点的父节点
preceding 选取当前元素之前的所有节点
following 选取当前元素之后的所有节点
sibling 选取当前节点的同级节点,即兄弟节点
preceding-sibling 选取当前节点的之前的同级节点
following-sibling 选取当前节点的之后的同级节点
child 选取当前节点的下层所有的子节点
text 复制代码
# 找到祖先节点
//input[@id="kw"]//ancestor::div

# 找到父节点
//input[@id="kw"]//parent::span

# 选取当前元素之前的所有节点
//input[@id="kw"]//preceding::span/span

1.9 元素定位总结

  1. ID定位是最快的,因为它是直接通过元素的ID进行匹配
  2. Name适用于表单元素等具有name属性的
  3. XPath和CSS Selector提供了强大的选择能力,可以精准地选择任何元素,可能会比其他方法慢
  4. Link Text和Partial Link Text适用于链接元素
  5. TagName和Class Name提供了元素类型或类的快速选择能力
  6. 新的Selenium推荐使用find_element()配合By类来代替之前的各种find_element_by_*方法,这样可以提高代码的可读性和未来兼容性
相关推荐
梦帮科技4 小时前
OpenClaw 桥接调用 Windows MCP:打造你的 AI 桌面自动化助手
人工智能·windows·自动化
feasibility.5 小时前
AI 编程助手进阶指南:从 Claude Code 到 OpenCode 的工程化经验总结
人工智能·经验分享·设计模式·自动化·agi·skills·opencode
xiaobaibai1536 小时前
营销自动化终极形态:AdAgent 自主闭环工作流全解析
大数据·人工智能·自动化
微祎_6 小时前
构建一个 Flutter 点击速度测试器:深入解析实时交互、性能度量与响应式 UI 设计
flutter·ui·交互
AAA阿giao6 小时前
从零拆解一个 React + TypeScript 的 TodoList:模块化、数据流与工程实践
前端·react.js·ui·typescript·前端框架
晚霞的不甘7 小时前
Flutter for OpenHarmony 构建简洁高效的待办事项应用 实战解析
flutter·ui·前端框架·交互·鸿蒙
百思可瑞教育7 小时前
构建自己的Vue UI组件库:从设计到发布
前端·javascript·vue.js·ui·百思可瑞教育·北京百思教育
池央7 小时前
CANN 诊断工具链深度解析:oam-tools 的自动化故障信息收集、软硬件状态快照与 AI Core 错误溯源机制
运维·人工智能·自动化
池央8 小时前
CANN 算子合规性与迁移性:自定义算子设计中的安全边界与属性兼容性
人工智能·自动化·信号处理
乾元8 小时前
终端安全(EDR):用深度学习识别未知勒索软件
运维·人工智能·网络协议·安全·网络安全·自动化·安全架构