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 元,你也来试试

相关推荐
奔跑吧邓邓子8 小时前
探索Selenium:自动化测试的神奇钥匙
自动化测试·selenium·测试工具
XxxxHe10 小时前
博客系统测试报告
功能测试·测试工具
淘小白_TXB219610 小时前
Python网页自动化Selenium中文文档
python·selenium·自动化·网页自动化
测试界清流15 小时前
Selenium4+Pytest自动化测试框架
selenium·测试工具·pytest
学不会就看1 天前
selenium学习实战【Python爬虫】
python·学习·selenium
CIb0la1 天前
Ai自动补全编程工具:llama vscode
运维·开发语言·学习·测试工具·程序人生
代码的乐趣2 天前
支持selenium的chrome driver更新到137.0.7151.68
chrome·selenium·测试工具
有风南来3 天前
算术图片验证码(四则运算)+selenium
自动化测试·python·selenium·算术图片验证码·四则运算验证码·加减乘除图片验证码