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

相关推荐
froginwe114 小时前
CSS 创建:从基础到高级
开发语言
人工干智能5 小时前
科普:python中你写的模块找不到了——`ModuleNotFoundError`
服务器·python
unicrom_深圳市由你创科技5 小时前
做虚拟示波器这种实时波形显示的上位机,用什么语言?
c++·python·c#
小敬爱吃饭5 小时前
Ragflow Docker部署及问题解决方案(界面为Welcome to nginx,ragflow上传文件失败,Docker中的ragflow-cpu-1一直重启)
人工智能·python·nginx·docker·语言模型·容器·数据挖掘
无限进步_5 小时前
【C++】电话号码的字母组合:从有限处理到通用解法
开发语言·c++·ide·windows·git·github·visual studio
宸津-代码粉碎机5 小时前
Spring Boot 4.0虚拟线程实战调优技巧,最大化发挥并发优势
java·人工智能·spring boot·后端·python
JJay.5 小时前
Android Kotlin 协程使用指南
android·开发语言·kotlin
知行合一。。。5 小时前
Python--04--数据容器(集合)
python
csbysj20205 小时前
jQuery 捕获详解
开发语言
C++ 老炮儿的技术栈5 小时前
GCC编译时无法向/tmp 目录写入临时汇编文件,因为设备空间不足,解决
linux·运维·开发语言·汇编·c++·git·qt