news 2026/6/9 23:46:21

常用的Selenium基础使用模板和简单封装

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
常用的Selenium基础使用模板和简单封装

前言

近来又用上了 Selneium ,因为反复用到,所以在这里将一些常用的方法封装起来,方便后续的使用。

在这篇文章中,我们将探讨Selenium的基础模板和基础封装,以便更好地理解Selenium的使用方法。

在Selenium的使用过程中,创建浏览器和 定位节点等是最常见的操作,

这里将常用的方法记录下来,以其减少后续在使用过程中的烦恼。

实现

基础使用模板

Selenium4创建浏览器需要传入Service。

在使用 Selenium 时候,有时候需要隐藏一些Selenium的特征。

代码

代码释义

·使用了 ChromeDriverManager 来处理 chromedriver.exe 驱动的问题

·考虑到驱动 和 js文件的问题,webdriver_path 和 js_file_path 都是可选参数,不传也不会报错

# -*- coding: utf-8 -*- # Name: model_main.py # Author: 小菜 # Date: 2023/5/20 10:45 # Description: from selenium import webdriver from selenium.webdriver.support.ui import WebDriverWait from selenium.webdriver.chrome.service import Service as ChromeService from webdriver_manager.chrome import ChromeDriverManager def init_driver(webdriver_path=None, js_file_path=None) -> webdriver.Chrome: """ 初始化浏览器驱动. Args: webdriver_path(str):浏览器驱动路径 js_file_path(str):js文件路径,用于隐藏Selenium的特征 Returns: driver: 浏览器驱动对象 """ driver = webdriver.Chrome(service=ChromeService(ChromeDriverManager(path=webdriver_path).install())) if js_file_path: js = open(file=js_file_path, encoding='utf-8') driver.execute_cdp_cmd( cmd_args={'source': js}, cmd="Page.addScriptToEvaluateOnNewDocument", ) return driver

使用

然后再使用一个或多个显示等待,优雅极了!

driver = init_driver() wait_5 = WebDriverWait(driver, 5) wait_10 = WebDriverWait(driver, 10)

简单封装

这份封装,称得上是优雅。使用了显示等待,兼容Selenium支持的各种定位方式!!!

可定位一个&多个节点、点击节点、文本输入、判断元素是否存在等~

代码

代码释义

·wait 和 value 为必选参数,其余的都是可选参数;

·by 默认的定位方式是 XPATH,可以传入其它定位方式,如 id, name 等;

·method 为 click 和 input,再加上默认的 定位,已经可以覆盖99%的节点操作;

·key 为 input 时候的文本内容,使用pyperclip 将 key复制到剪切板,然后执行键盘事件进行 Ctrl + V 黏贴,效率更高;

·其余的看下面的 代码 和 使用 。

import time import pyperclip from selenium.webdriver import Keys from selenium.webdriver.support.ui import WebDriverWait from selenium.webdriver.support import expected_conditions as ec from selenium.common.exceptions import ( TimeoutException, NoSuchElementException, InvalidSelectorException, ) def locate_and_operate_element(wait: WebDriverWait, by='xpath', value=None, method=None, key=None, is_more=False, check_visibility=False): """ 定位元素并执行操作。 Args: wait (WebDriverWait): WebDriverWait 对象,用于显示等待元素出现 by: 元素定位方式(例如 By.ID,By.XPATH)。 value: 元素定位值(例如元素的 ID,XPath 表达式)。 method (str): 操作方法(默认为 None)。 key: 输入文本的值(默认为 None)。 is_more (bool): 是否返回多个元素,默认为 False。 check_visibility (bool): 是否检查元素可见性(默认为 False)。 Returns: WebElement: 元素对象(当 method 参数为 None 且 is_more 参数为 False 时); None: 表示元素未在指定时间内出现或无法定位到指定的元素; List[WebElement]: 多个元素对象列表(当 method 参数为 None 且 is_more 参数为 True 时)。 Raises: TimeoutException: 超时异常,表示元素未在指定时间内出现。 NoSuchElementException: 未找到元素异常,表示无法定位到指定的元素。 InvalidSelectorException: 选择器无效异常,表示使用了无效的选择器。 """ assert isinstance(wait, WebDriverWait), "wait 参数必须是 WebDriverWait 类型。" assert value, f"{value} 不能为空." try: element = wait.until(ec.presence_of_element_located((by, value))) # 根据指定的操作方法执行相应操作 # 如果不指定方法, 默认为寻找对象是否存在 if not method: if is_more: return wait.until(ec.presence_of_all_elements_located((by, value))) if check_visibility: return wait.until(ec.visibility_of_element_located((by, value))) return wait.until(ec.presence_of_element_located((by, value))) if method == 'click': wait.until(ec.element_to_be_clickable((by, value))).click() time.sleep(2) elif method == 'input': assert key wait.until(ec.visibility_of_element_located((by, value))) pyperclip.copy(key) time.sleep(0.2) element.send_keys(Keys.CONTROL, 'A') time.sleep(0.2) element.send_keys(Keys.DELETE) time.sleep(0.2) element.send_keys(Keys.CONTROL, 'V') time.sleep(0.2) except TimeoutException: print(f"超时:{by}={value}") return None except NoSuchElementException: print(f"无法找到元素:{by}={value}") return None except InvalidSelectorException: print(f"选择器无效:{by}={value}") return None

使用

结合上面的 基础使用模板:

driver = init_driver() wait_5 = WebDriverWait(driver, 5) """默认定位方式为xpath""" # 定位某个节点 locate_and_operate_element(wait_5, value='specify_node') # 定位多个节点 locate_and_operate_element(wait_5, value='specify_nodes', is_more=True) # 判断某个节点是否可见 locate_and_operate_element(wait_5, value='specify_node', check_visibility=True) # 点击指定节点 locate_and_operate_element(wait_5, value='specify_node', method='click') # 输入内容 locate_and_operate_element(wait_5, value='specify_node', method='input')

总结

本文介绍了在 Selenium使用中的基础使用模板和简单封装。

·基础使用模板,针对隐藏chromedriver.exe驱动和隐藏Selenium特征做了通用适配,从此再也不用担心驱动出错和Selenium被网站发现的问题;

·简单封装,针对定位节点、点击节点、输入文本等操作做了封装,并且针对代码给出了详细的注释。

最后作为一位过来人也是希望大家少走一些弯路,在这里我给大家分享一些软件测试的学习资料,这些资料希望能给你前进的路上带来帮助。

视频文档获取方式:
这份文档和视频资料,对于想从事【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴我走过了最艰难的路程,希望也能帮助到你!以上均可以分享,点下方小卡片即可自行领取。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/9 17:27:35

清华镜像站提供CentOS软件包下载地址

清华镜像站加速深度学习环境部署:以 TensorFlow-v2.9 为例 在人工智能项目快速迭代的今天,一个常见的现实困境是:算法设计只占开发时间的30%,而环境搭建和依赖调试却消耗了近一半的时间。尤其是当团队成员分布在不同城市、使用不同…

作者头像 李华
网站建设 2026/6/9 19:49:19

90%开发者忽略的模块安全问题:类文件操作标准化迫在眉睫

第一章:Java模块格类文件操作标准化的紧迫性在现代企业级Java应用开发中,类路径(classpath)与模块路径(module path)的混乱管理已成为影响系统稳定性与可维护性的关键隐患。随着Java 9引入模块系统&#xf…

作者头像 李华
网站建设 2026/6/8 18:56:24

Kafka Streams + Project Reactor集成深度剖析(企业级实时处理架构机密)

第一章:Kafka Streams Project Reactor集成概述在现代响应式系统架构中,将事件流处理与非阻塞编程模型结合已成为提升吞吐量与降低延迟的关键策略。Kafka Streams 提供了轻量级的流处理能力,而 Project Reactor 作为 JVM 上主流的响应式编程…

作者头像 李华
网站建设 2026/6/9 19:49:15

Conda环境导出为YAML文件供TensorFlow镜像复用

Conda环境导出为YAML文件供TensorFlow镜像复用 在深度学习项目开发中,一个常见的困扰是:“代码在我机器上能跑,为什么换台设备就报错?”这种“依赖地狱”问题的根源往往不在于模型本身,而在于环境差异——不同版本的 P…

作者头像 李华
网站建设 2026/6/8 19:39:08

收藏!11种大模型微调方法详解,从LORA到QLORA一篇掌握

这篇文章系统介绍了11种大型语言模型的微调方法,包括前缀调优、提示调优、P-Tuning v2、LORA及其变种(DyLORA、AdaLORA)、QLORA、OA-LOR、LongLORA、VeRA和S-LORA等。这些方法各有特点,旨在提高微调效率、减少参数量和计算资源消耗,同时保持或…

作者头像 李华
网站建设 2026/6/9 23:40:59

算法定义未来:Deepoc-M重构通信技术新生态

当顶尖数学理论与产业应用深度融合,通信行业正在经历一场静默的技术革命在通信技术快速迭代的今天,中小企业往往面临核心技术研发门槛高、创新资源有限的困境。Deepoc-M模型通过将前沿数学理论转化为实用工具,为通信行业特别是中小企业提供了…

作者头像 李华