ChromeDriverManager:自动下载和管理chromedriver版本

一、背景

在使用Selenium进行浏览器自动化测试时,需要配置chromedriver。但是chromedriver需要与本地Chrome浏览器版本匹配,不同操作系统对应的chromedriver版本也不同。遇到Chrome浏览器更新时也都需要手动下载新的chromedriver版本替换,同时考虑操作系统版本,将非常麻烦。

二、ChromeDriverManager的作用

ChromeDriverManager可以自动下载和管理chromedriver。它可以:

  • 根据本地Chrome浏览器版本自动下载匹配的chromedriver
  • 自动判断操作系统版本,下载对应版本的chromedriver
  • 设置chromedriver的下载目录,方便管理
    这样就无需关心chromedriver的版本和路径,可以降低测试维护的成本。

三、ChromeDriverManager的使用方法

  1. 安装webdriver_manager模块
py 复制代码
pip install webdriver_manager
  1. 导入ChromeDriverManager和webdriver模块
py 复制代码
from selenium import webdriver
from webdriver_manager.chrome import ChromeDriverManager
  1. 创建ChromeDriverManager对象,指定下载路径(可选)
py 复制代码
manager = ChromeDriverManager(path="./drivers")
  1. 调用install()方法下载匹配版本的chromedriver
py 复制代码
driver_path = manager.install()
  1. 创建Service对象,传入chromedriver路径
py 复制代码
service = Service(driver_path)
  1. 创建ChromeDriver,传入service参数
py 复制代码
driver = webdriver.Chrome(service=service)

这样就可以通过简单的代码自动下载和配置chromedriver,非常方便。

四、主要优点

  • 自动管理chromedriver,使代码简洁,无需指定chromedriver路径
  • 随Chrome浏览器更新自动获取对应版本的chromedriver
  • 自动判断操作系统版本,下载正确的chromedriver
  • 可以设置chromedriver下载目录,不会污染项目目录
  • 提高代码可移植性,可轻松运行在不同机器上

五、完整示例

下面是一个使用ChromeDriverManager的完整示例:

py 复制代码
from selenium import webdriver
from selenium.webdriver.chrome.service import Service  # 导入Service类
import os

from selenium.webdriver.common.by import By
from webdriver_manager.chrome import ChromeDriverManager
import time

current_dir = os.path.dirname(os.path.abspath(__file__))
# 获取当前文件所在目录的绝对路径

driver_path = os.path.join(current_dir, 'drivers')
# 设置驱动下载目录为当前目录下的drivers文件夹
os.makedirs(driver_path, exist_ok=True)
# 创建目录 如果存在则跳过创建

manager = ChromeDriverManager(path=driver_path)
# 设置驱动下载管理器下载路径
chromedriver_path = manager.install()
# 下载匹配本地Chrome版本的驱动

# 创建驱动服务对象,传入下载的驱动执行路径
service = Service(chromedriver_path)

# 创建Chrome浏览器驱动时,传入驱动服务对象
# 该服务包含了驱动的路径,版本等信息
driver = webdriver.Chrome(service=service)

# 后续正常编写网页自动化代码
target_url = "https://www.baidu.com"
driver.get(target_url)
print(f"成功访问网页:{target_url}")
sleep(5)

driver.quit()

参考链接:https://blog.csdn.net/qq_42531954/article/details/131863711

相关推荐
0思必得02 小时前
[Web自动化] Selenium元素定位
前端·python·selenium·自动化·html
weixin_419658312 小时前
UISpy:Windows 界面控件的“显微镜“[特殊字符]
windows·python·测试工具·ui
天燹2 小时前
Qt 6 嵌入 Android 原生应用完整教程
android·开发语言·qt
liu****2 小时前
第一章 Qt 概述
开发语言·c++·qt
不如语冰2 小时前
AI大模型入门1.1-python基础-数据结构
数据结构·人工智能·pytorch·python·cnn
知行合一。。。2 小时前
Python--04--数据容器(列表 List)
开发语言·python
程芯带你刷C语言简单算法题2 小时前
Day48~对于高度为 n 的台阶,从下往上走,每一步的阶数为 1,2,3 中的一个。问要走到顶部一共有多少种走法
c语言·开发语言·学习·算法·c
csbysj20202 小时前
SQL NOT NULL约束详解
开发语言
杰瑞哥哥2 小时前
【时间序列与深度学习】(一)经济计量基础ARIMA模型
python·时间序列·金融工程