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

Selenium 查找页面元素的方式

Selenium 查找页面元素的方式

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

基本定位方式

  1. 通过ID定位

    driver.find_element(By.ID, "element_id")
    
  2. 通过Name定位

    driver.find_element(By.NAME, "element_name")
    
  3. 通过Class Name定位

    driver.find_element(By.CLASS_NAME, "class_name")
    
  4. 通过Tag Name定位

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

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

    driver.find_element(By.PARTIAL_LINK_TEXT, "部分链接文本")
    

CSS 选择器定位

driver.find_element(By.CSS_SELECTOR, "css_selector")

示例:

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

XPath 定位

driver.find_element(By.XPATH, "xpath_expression")

示例:

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

查找多个元素

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

elements = driver.find_elements(By.CSS_SELECTOR, ".list-item")

相对定位(Selenium 4新增)

Selenium 4 引入了相对定位器:

from selenium.webdriver.support.relative_locator import locate_withpassword = 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. 对于动态元素,考虑使用显式等待结合定位策略

示例代码

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

在这里插入图片描述

相关文章:

  • 企业培训学习考试系统源码 ThinkPHP框架+Uniapp支持多终端适配部署
  • STM32手册上标称的18MHz GPIO翻转速度和你实际测量到的速度之间的差异是预期之内且合理的
  • WebRTC中的几个Rtp*Sender
  • day028-Shell自动化编程-判断进阶
  • @Builder的用法
  • 【threejs】每天一个小案例讲解
  • 【数据结构】5. 双向链表
  • 《前端面试题:CSS3新特性》
  • Spring AI学习一
  • 【面经分享】京东
  • 【快速预览经典深度学习模型:CNN、RNN、LSTM、Transformer、ViT全解析!】
  • uv管理spaCy语言模型
  • vue2 跳转进入页面调用接口,刷新页面的时候不更新接口,利用页面存储进行判断写逻辑
  • deque实践~
  • uniapp图片文档预览
  • uniappx插件nutpi-idcard 开发与使用指南(适配鸿蒙)
  • uniapp微信小程序视频实时流+pc端预览方案
  • 【新品解读】一板多能,AXRF49 定义新一代 RFSoC FPGA 开发平台
  • SFTP与SSH分离
  • 小知识点一:无刷电机
  • 设计网站导航大全/搜索引擎优化营销
  • 中山建设工程招聘信息网站/推广app平台
  • 企业在线/seo排名赚钱
  • 怎么让人理解网站建设/seo网络推广有哪些
  • 怎么创作自己的网站/新闻早知道
  • 湘潭做网站问下磐石网络/seo分析seo诊断