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

selenium自动下载更新浏览器对应的webdriver

        相信做过UI自动化的朋友们,都会碰到一个问题,那就是经常莫名其妙的自动化框架跑不起来了,然后一查发现是浏览器更新了,对应的webdriver驱动不匹配了,然后就得自己去看浏览器版本,然后去对应浏览器的webdriver网站下载匹配版本,然后再放到环境变量里,很麻烦。

        那有没有什么方法让框架自己每次去检查浏览器版本,然后发现版本不匹配时,自己去下载对应驱动,然后安装呢,还真有,废话少说,直接上干货。

1.下载依赖包

pip install webdriver-manager

2.封装获取webdriver的方法

        笔者这里封装的方法适合UI自动化框架使用,如果只是单纯写脚本不用这么复杂,封装的方法支持自动下载更新任意浏览器(比如谷歌、eage等)的webdriver,并且支持启动webdriver失败时,自动重试机制(因为经测试发现这个依赖包经常容易第一次启动失败)。

import os
import shutilfrom selenium import webdriver
from selenium.webdriver.chrome.service import Service as ChromeService
from selenium.webdriver.edge.service import Service as EdgeService
from selenium.webdriver.firefox.service import Service as FirefoxService
from webdriver_manager.chrome import ChromeDriverManager
from webdriver_manager.firefox import GeckoDriverManager
from webdriver_manager.microsoft import EdgeChromiumDriverManagerfrom common.base_log import loggerclass GetDriver:"""根据driver_type,自动安装下载浏览器驱动,并返回driver:return:driver"""def __init__(self, driver_type: str):# 判断drivers_type是不是字符串,再判断driver_type的浏览器类型是否符合指定类型if isinstance(driver_type, str) and (driver_type.lower() in ["chrome", "chrome-headless", "firefox", "firefox-headless", "edge"]):self.driver_type = driver_type.lower()else:logger.error(f"不支持该浏览器类型:{driver_type}")raise TypeError(f"不支持该浏览器类型:{driver_type}")def get_driver(self):"""启动 driver,失败时清理缓存后重试一次"""try:return self._start_driver()except Exception as first_exc:logger.warning(f" 启动[{self.driver_type}]浏览器失败:{first_exc}")logger.info("准备清理驱动缓存后重试启动...")self._clear_webdriver_cache()try:logger.info(f"开始尝试重新启动[{self.driver_type}]...")return self._start_driver()except Exception as final_exc:logger.error(f"[{self.driver_type}] 浏览器清理缓存后仍然启动失败:{final_exc}")raisedef _start_driver(self):"""根据driver_type初始化不同的浏览器驱动"""match self.driver_type:case "chrome":return self._chrome_driver()case "chrome-headless":return self._chrome_headless_driver()case "firefox":return self._firefox_driver()case "firefox-headless":return self._firefox_headless_driver()case "edge":return self._edge_driver()case _:raise ValueError(f"不支持的浏览器类型:{self.driver_type}")def _clear_webdriver_cache(self):"""清理webdriver-manager下载的驱动缓存"""cache_dir = os.path.expanduser("~/.wdm")if os.path.exists(cache_dir):logger.info(f"开始清理缓存目录:{cache_dir}")try:shutil.rmtree(os.path.expanduser("~/.wdm"), ignore_errors=True)logger.info("清理 webdriver 缓存成功")except Exception as e:logger.warning(f"清理缓存失败:{e}")else:logger.info("缓存目录不存在,无需清理")def _setup_driver(self, driver):"""通用 driver 设置:最大化窗口 + 隐式等待 + 清理 cookies"""driver.maximize_window()driver.implicitly_wait(10)driver.delete_all_cookies()  # 清除浏览器所有缓存def _chrome_driver(self):# chrome浏览器# selenium 3的写法# driver = webdriver.Chrome(ChromeDriverManager().install())# selenium 4的写法options = webdriver.ChromeOptions()# 去掉"chrome正受到自动化测试软件的控制"的提示条options.add_experimental_option("excludeSwitches", ["enable-automation"])options.add_experimental_option('useAutomationExtension', False)driver = webdriver.Chrome(service=ChromeService(ChromeDriverManager().install()), options=options)self._setup_driver(driver)return driverdef _chrome_headless_driver(self):# chrome headless模式# 参数说明,参考地址:https://github.com/GoogleChrome/chrome-launcher/blob/master/docs/chrome-flags-for-tools.md#--enable-automationchrome_option = webdriver.ChromeOptions()chrome_option.add_argument("--headless")chrome_option.add_argument("--no-sandbox")  # 注意:linux运行必须要有这个chrome_option.add_argument("--window-size=1920x1080")# 本地chrome浏览器# selenium 3的写法# driver = webdriver.Chrome(ChromeDriverManager().install())# selenium 4的写法driver = webdriver.Chrome(service=ChromeService(ChromeDriverManager().install()), options=chrome_option)self._setup_driver(driver)return driverdef _firefox_driver(self):# firefox浏览器# selenium 3# driver = webdriver.Firefox(executable_path=GeckoDriverManager().install())# selenium 4driver = webdriver.Firefox(service=FirefoxService(GeckoDriverManager().install()))self._setup_driver(driver)return driverdef _firefox_headless_driver(self):# firefox headless模式firefox_options = webdriver.FirefoxOptions()firefox_options.add_argument("--headless")firefox_options.add_argument("--disable-gpu")# selenium 3# driver = webdriver.Firefox(executable_path=GeckoDriverManager().install())# selenium 4driver = webdriver.Firefox(service=FirefoxService(GeckoDriverManager().install()), options=firefox_options)self._setup_driver(driver)return driverdef _edge_driver(self):# Edge浏览器# selenium 3# driver = webdriver.Edge(EdgeChromiumDriverManager().install())# selenium 4edge_options = webdriver.EdgeOptions()edge_options.use_chromium = True# 屏蔽inforbaredge_options.add_experimental_option('useAutomationExtension', False)edge_options.add_experimental_option('excludeSwitches', ['enable-automation', 'enable-logging'])driver = webdriver.Edge(service=EdgeService(EdgeChromiumDriverManager().install()), options=edge_options)self._setup_driver(driver)return driverif __name__ == '__main__':driver = GetDriver("chrome").get_driver()print(driver)driver.get("https://www.baidu.com")

http://www.dtcms.com/a/357774.html

相关文章:

  • 关于shell命令的扩展
  • log4jshell CVE-2021-44228 复现
  • R1 快开门式压力容器操作证考试大纲解读:重点模块与考核标准
  • Linux Shell 编程
  • 淘宝商品评论接口技术实现:从评论获取到情感分析全流程方案
  • SQL知识
  • 序列容器(vector,deque,list)
  • 4x12G-SDI(四链接12G-SDI)
  • PCIe 6.0 TLP结构解析:深入理解事务层数据包的设计与实现
  • Windows Command Line Windows 命令行
  • 【RAG Agent实战】告别“单线程”RAG:用查询理解与LangGraph构建能处理复杂意图的高级代理
  • ros2--action/动作--接口
  • 2024年12月 Python(四级)真题解析#中国电子学会#全国青少年软件编程等级考试
  • 中科米堆CASAIM五金配件三维扫描测量尺寸形位公差
  • MySQL 中如果发生死锁应该如何解决?
  • OpenAI宣布正式推出Realtime API
  • ADC模数转换
  • Set和Map
  • AI的“科学革命”:Karpathy吹响号角,从“经院哲学”走向“实验科学”
  • 【.net core】【NPOI】读取表格信息(处理合并行表格数据)
  • vscode里面可以批量放弃更改
  • Linux驱动异步通知机制详解
  • Labview邪修01:贪吃蛇
  • 【完整源码+数据集+部署教程】控制台缺陷检测系统源码和数据集:改进yolo11-repvit
  • IDEA编译报错:Error:(3, 28) java: 程序包com.alibaba.fastjson不存在
  • GPFS性能优化
  • zyplayer-doc:AI 驱动的智能知识库
  • LeetCode力扣-hot100系列(2)
  • MQTT高延迟通信优化指南
  • 解密企业数据安全:服务业加密软件的核心价值