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

Selenium WebDriver 中用于查找网页元素的两个方法

这里提供了 Selenium WebDriver 中用于查找元素的两个方法:find_element()find_elements()

  1. find_element(by='id', value: Optional[str] = None) → selenium.webdriver.remote.webelement.WebElement

    • 这个方法用于查找满足指定定位策略(By strategy)和定位器(locator)条件的单个元素。
    • 示例用法:element = driver.find_element(By.ID, 'foo')
    • 返回类型:WebElement,表示找到的单个元素。
  2. find_elements(by='id', value: Optional[str] = None) → List[selenium.webdriver.remote.webelement.WebElement]

    • 这个方法用于查找满足指定定位策略和定位器条件的所有元素,返回一个元素列表。
    • 示例用法:elements = driver.find_elements(By.CLASS_NAME, 'foo')
    • 返回类型:List[selenium.webdriver.remote.webelement.WebElement],表示找到的元素列表。

这两个方法可以根据不同的定位策略(如 By.ID、By.CLASS_NAME、By.XPATH 等)和对应的定位器条件来定位页面上的元素。通过这些方法,你可以在自动化测试脚本中准确地定位和操作页面上的元素。

需要注意的是,在调用这两个方法之前,你需要先创建一个 WebDriver 实例(例如 webdriver.Chrome()),然后使用该实例调用这些方法来查找页面上的元素。

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()try:driver.get("https://www.hao123.com/")# print('*****driver_type',type(driver)) # driver_type <class 'selenium.webdriver.chrome.webdriver.WebDriver'>input_elements = driver.find_elements(By.TAG_NAME, "input")for input_element in input_elements:print(input_element.get_attribute("outerHTML"))print('*'*35)lielements = driver.find_elements(By.CSS_SELECTOR, "ul.boxhot li")for li in lielements:print(li.text)search_input = driver.find_element(By.CSS_SELECTOR, 'input[data-hook="searchInput"]')# print('*****search_input_type',type(search_input)) # search_input_type <class 'selenium.webdriver.remote.webelement.WebElement'>search_input.send_keys("Selenium库")search_button = driver.find_element(By.CSS_SELECTOR, 'input[data-hook="searchSubmit"]')search_button.click()handles = driver.window_handlesprint(type(handles))if len(handles) > 1:driver.switch_to.window(handles[1])# Wait for the search results to load completelyWebDriverWait(driver, 10).until(EC.presence_of_element_located((By.CSS_SELECTOR, 'div[id="content_left"]')))
finally:driver.quit()# In this updated version, we added the following imports:
# from selenium.webdriver.support.ui import WebDriverWait
# from selenium.webdriver.support import expected_conditions as EC
# We then added a WebDriverWait statement to wait for the presence of a specific element in the search results page:
# WebDriverWait(driver, 10).until(EC.presence_of_element_located((By.CSS_SELECTOR, 'div[class="search-list-item"]')))
# This statement waits for up to 10 seconds for an element with the CSS selector 'div[class="search-list-item"]' to appear on the page. 
# Once the element appears, the script continues to execute.# Note that you may need to adjust the CSS selector or the wait time to suit your specific needs.
# (By.CSS_SELECTOR, 'div[id="content_left"]'), 

 class By:
selenium.webdriver.common.by.By 类中各个常量的具体定位策略及其说明。
下面是这些常量的含义和用法:
By.CLASS_NAME: 根据元素的 class name 属性进行定位。
By.CSS_SELECTOR: 根据 CSS 选择器进行定位。
By.ID: 根据元素的 id 属性进行定位。
By.LINK_TEXT: 根据链接文本进行定位,适用于 <a> 标签。
By.NAME: 根据元素的 name 属性进行定位。
By.PARTIAL_LINK_TEXT: 根据链接文本的部分匹配进行定位。
By.TAG_NAME: 根据元素的标签名进行定位。
By.XPATH: 根据 XPath 表达式进行定位。

这些定位策略可根据元素的不同属性或特征进行定位,以便在 WebDriver 中找到所需的元素。您可以根据实际情况选择合适的定位策略来定位元素。
​​​​​​​定位策略主要用于 find_element()find_elements() 方法中的 locator 参数。通过指定相应的定位策略和对应的值,您可以精确定位到要操作的元素。

class By:"""Set of supported locator strategies."""ID = "id"XPATH = "xpath"LINK_TEXT = "link text"PARTIAL_LINK_TEXT = "partial link text"NAME = "name"TAG_NAME = "tag name"CLASS_NAME = "class name"CSS_SELECTOR = "css selector"

http://www.lryc.cn/news/321871.html

相关文章:

  • python 常用装饰器
  • 深入解析MySQL日志系统:Binlog、Undo Log和Redo Log
  • 强森算法求两点最短路径的基本流程及代码实现
  • 数据结构入门篇 之 【双链表】的实现讲解(附完整实现代码及顺序表与线性表的优缺点对比)
  • 什么是零日攻击?
  • 阿里云2025届春招实习生招聘
  • 简单了解多线程
  • GEE对上传并读取CSV文件
  • vulnhub-----SickOS靶机
  • slab分配器
  • MySQL面试题之基础夯实
  • feign请求添加拦截器
  • 蓝桥杯之简单数论冲刺
  • Http的缓存有哪些
  • Linux 网络虚拟化 Macvlan(基于物理网络接口虚拟网络接口) 认知
  • Spark-Scala语言实战(1)
  • NBlog Java定时任务-备份MySQL数据
  • 微信小程序项目实战遇到的问题
  • 网络原理(3)——TCP协议
  • nginx多级代理配置获取客户端真实ip
  • Django框架的全面指南:从入门到高级【第128篇—Django框架】
  • C++类和对象基础
  • 消息队列常见的两种消费模式
  • php的伪协议详解
  • 【研发日记】Matlab/Simulink技能解锁(四)——在Simulink Debugger窗口调试
  • 沪深主板打板胜率统计
  • Python中的列表推导式(List Comprehension)
  • MusicHiFi: Fast High-Fidelity Stereo Vocoding
  • 完美解决 RabbitMQ可视化界面Overview不显示折线图和队列不显示Messages
  • matlab 混沌系统李雅普洛夫指数谱相图分岔图和庞加莱界面