Selenium 查找页面元素的方式

Selenium 查找页面元素的方式

Selenium 提供了多种方法来查找网页中的元素,以下是主要的定位方式:

基本定位方式

  1. 通过ID定位

    python 复制代码
    driver.find_element(By.ID, "element_id")
  2. 通过Name定位

    python 复制代码
    driver.find_element(By.NAME, "element_name")
  3. 通过Class Name定位

    python 复制代码
    driver.find_element(By.CLASS_NAME, "class_name")
  4. 通过Tag Name定位

    python 复制代码
    driver.find_element(By.TAG_NAME, "tag_name")
  5. 通过Link Text定位(精确匹配)

    python 复制代码
    driver.find_element(By.LINK_TEXT, "链接文本")
  6. 通过Partial Link Text定位(部分匹配)

    python 复制代码
    driver.find_element(By.PARTIAL_LINK_TEXT, "部分链接文本")

CSS 选择器定位

python 复制代码
driver.find_element(By.CSS_SELECTOR, "css_selector")

示例:

  • "#id" - 通过ID
  • ".class" - 通过类名
  • "div > input" - 子元素
  • "input[type='text']" - 属性选择器

XPath 定位

python 复制代码
driver.find_element(By.XPATH, "xpath_expression")

示例:

  • "//input" - 所有input元素
  • "//div[@id='main']" - 特定属性的div
  • "//a[contains(text(),'登录')]" - 包含特定文本的链接

查找多个元素

使用find_elements(注意复数形式)返回匹配的所有元素列表:

python 复制代码
elements = driver.find_elements(By.CSS_SELECTOR, ".list-item")

相对定位(Selenium 4新增)

Selenium 4 引入了相对定位器:

python 复制代码
from selenium.webdriver.support.relative_locator import locate_with

password = driver.find_element(By.ID, "password")
email = driver.find_element(locate_with(By.TAG_NAME, "input").above(password))

相对定位方法包括:above(), below(), to_left_of(), to_right_of(), near()

最佳实践

  1. 优先使用ID定位,因为ID通常是唯一的且效率最高
  2. 当ID不可用时,考虑使用CSS选择器
  3. XPath功能强大但执行较慢,应谨慎使用
  4. 对于动态元素,考虑使用显式等待结合定位策略

示例代码

python 复制代码
from selenium import webdriver
from selenium.webdriver.common.by import By
from selenium.webdriver.support.ui import WebDriverWait
from selenium.webdriver.support import expected_conditions as EC

driver = webdriver.Chrome()
driver.get("https://example.com")

# 使用显式等待定位元素
element = WebDriverWait(driver, 10).until(
    EC.presence_of_element_located((By.ID, "dynamic-element"))
)

# 使用CSS选择器
submit_button = driver.find_element(By.CSS_SELECTOR, "button.submit-btn")

# 使用XPath
link = driver.find_element(By.XPATH, "//a[contains(@href, 'logout')]")

记得在使用完WebDriver后调用driver.quit()来关闭浏览器和释放资源。

支付宝这一次力度够大的啊,后台看到有人居然领了 20 元,你也来试试

相关推荐
卓码软件测评6 小时前
第三方软件测评机构:【Gatling与JMeter的架构对比:异步与非阻塞I/O模型如何实现更高并发】
测试工具·jmeter·架构·测试用例·负载均衡·压力测试
美团程序员6 小时前
一篇文章教你搞定:”xx 功能如何测试?“常见面试题型!
测试工具·面试·职场和发展·测试用例
软件测试雪儿11 小时前
高频Postman软件测试面试题
测试工具·lua·postman
2501_9151063213 小时前
iOS App 测试工具全景分析,构建从开发调试到线上监控的多阶段工具链体系
android·测试工具·ios·小程序·uni-app·iphone·webview
小白学大数据15 小时前
构建混合爬虫:何时使用Requests,何时切换至Selenium处理请求头?
爬虫·python·selenium·测试工具
Hacker_Fuchen17 小时前
POST请求提交数据的三种方式及通过Postman实现
自动化测试·软件测试·测试工具·postman
安然无虞17 小时前
JMeter性能测试工具·下
开发语言·测试工具·jmeter
Wpa.wk19 小时前
自动化测试环境配置-java+python
java·开发语言·python·测试工具·自动化
程序员三藏1 天前
Jmeter自动化测试
自动化测试·软件测试·python·测试工具·jmeter·测试用例·接口测试
西游音月1 天前
(4)pytest+Selenium自动化测试-元素定位之CSS Selector定位
css·selenium·pytest