news 2026/5/8 21:17:32

推荐一款新的自动化测试框架:DrissionPage

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
推荐一款新的自动化测试框架:DrissionPage

今天给大家推荐一款基于Python的网页自动化工具:DrissionPage。这款工具既能控制浏览器,也能收发数据包,甚至能把两者合而为一,简单来说:集合了WEB浏览器自动化的便利性和 requests 的高效率优点。

一、DrissionPage框架产生背景

对网页实现自动化,通常会有两类形式:

前者轻量级,速度快,例如requests 库。但requests面对需要登录的网站时,往往还要应付验证码、JS 混淆、签名参数等反爬手段,门槛较高。若数据是由 JS 计算生成的,还须重现计算过程,开发效率不高。

而后者直接使用浏览器,模拟用户行为,如Selenium库,可以很大程度上绕过这些坑,但浏览器运行效率不高。

因此,DrissionPag设计初衷,是将它们合而为一,能够在不同须要时切换相应模式,并提供一种人性化的使用方法,提高开发和运行效率。

为什么叫DrissionPag

Selenium框架用于操作浏览器的对象叫 Driver,requests 用于管理请求连接的对象叫 Session,因此Drission 就是它们两者的合体。在旧版本中,是通过对 selenium 和 requests 的重新封装实现的。

但从 3.0 版开始,作者另起炉灶,用chromium协议自行实现了 selenium 全部功能,从而摆脱了对 selenium 的依赖,功能更多更强,运行效率更高,开发更灵活。

二、DrissionPage框架亮点特色

本库采用全自研的内核,对比 selenium,有以下优点:

三、安装搭建

说了这么多,相信很多人已经跃跃欲试了,怎么快速搭建这套框架,先要准备一些基础环境。

环境准备

项目地址:

https://gitee.com/g1879/DrissionPage

使用 pip 安装 DrissionPage:

pip install DrissionPage

另外在开始之前,我们先进行一些简单设置。如果只使用收发数据包功能,无须任何准备工作。

如果要控制浏览器,须设置浏览器路径。程序默认设置控制 Chrome,所以以下用 Chrome 作为演示。如果要使用 Edge 或其它 Chromium 内核浏览器,设置方法是一样的。

设置浏览器路径:

from DrissionPage.easy_set import set_paths set_paths(browser_path=r'这里修改为您的Chrome浏览器exe文件路径')

这段代码会记录 Chrome 浏览器路径到配置文件。由于路径设置只要运行一次即可,不要写到正式程序里。一般建议新建一个临时 py 文件,并输入以下代码,填入您电脑里的 Chrome 浏览器 exe 文件路径,然后执行。

四、实战一下

1、尝试启动浏览器:

from DrissionPage import ChromiumPage page = ChromiumPage() page.get('https://www.baidu.com')

执行以下代码,如果正常启动了浏览器并且访问了百度,说明可直接使用,跳过后面的步骤即可。

执行代码前,如果已有打开的 Chrome 浏览器,请关闭。

2、与selenium框架代码对比

#案例一:用显性等待方式查找第一个文本包含 some text 的元素。 # 使用 selenium: element = WebDriverWait(driver).until(ec.presence_of_element_located((By.XPATH, '//*[contains(text(), "some text")]'))) # 使用 DrissionPage: element = page('some text') #案例二:跳转到第一个标签页 # 使用 selenium: driver.switch_to.window(driver.window_handles[0]) # 使用 DrissionPage: page.to_tab(0) # 案例三:拖拽一个元素 # 使用 selenium: ActionChains(driver).drag_and_drop(ele1, ele2).perform() # 使用 DrissionPage: ele1.drag_to(ele2)

以上代码实现一模一样的功能,但DrissionPage代码明显更简洁优雅。

3、与requests框架代码对比

# 案例一:获取元素内容 url = 'https://baike.baidu.com/item/python' # 使用 requests: from lxml import etree headers = {'User-Agent':'Mozilla/5.0 (Windows NT 6.3; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/41.0.2272.118 Safari/537.36'} response = requests.get(url, headers = headers) html = etree.HTML(response.text) element = html.xpath('//h1')[0] title = element.text # 使用 DrissionPage: page = WebPage('s') page.get(url) title = page('tag:h1').text

4、DrissionPage不同模式切换

例如:用浏览器登录网站,然后切换到 requests 读取网页。两者会共享登录信息。

from DrissionPage import WebPage from time import sleep # 创建页面对象,默认 d 模式 page = WebPage() # 访问个人中心页面(未登录,重定向到登录页面) page.get('https://gitee.com/profile') # 使用 selenium 输入账号密码登录 page.ele('@id:user_login').input('your_user_name') page.ele('@id:user_password').input('your_password\n') sleep(1) # 切换到 s 模式 page.change_mode() # 登录后 session 模式的输出 print('登录后title:', page.title, '\n')

五、小结

DrissionPage体验一番后,虽然还是存在一些不足的地方,但整得来讲,很多设计理念还是非常值得借鉴的,更多功能就留给大家去探索了,项目文档地址:

http://g1879.gitee.io/drissionpagedocs/

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

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

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

Cox回归分析效率提升3倍,R语言高级建模技巧大公开

第一章:临床数据的 R 语言 Cox 回归优化在处理生存分析问题时,Cox 比例风险模型是临床研究中广泛应用的统计方法。它能够评估多个协变量对生存时间的影响,同时无需假设基础风险函数的具体形式。利用 R 语言中的 survival 包,可以高…

作者头像 李华
网站建设 2026/5/6 6:07:23

【渲染的抗锯齿终极指南】:揭秘图像锯齿根源与5种高效解决方案

第一章:渲染的抗锯齿在计算机图形学中,抗锯齿(Anti-Aliasing)是提升图像视觉质量的关键技术之一。由于数字图像由离散像素构成,在渲染斜线或曲线边缘时容易出现阶梯状的“锯齿”现象。抗锯齿通过平滑这些边缘&#xff…

作者头像 李华
网站建设 2026/5/6 6:07:23

【医疗行业数据防护】:满足HIPAA合规要求的5大技术控制措施

第一章:医疗数据的 HIPAA 合规概述在医疗信息化快速发展的背景下,保护患者隐私和确保数据安全成为核心议题。HIPAA(Health Insurance Portability and Accountability Act)作为美国医疗数据保护的基石性法规,为个人健康…

作者头像 李华
网站建设 2026/5/6 6:07:22

为什么你的低代码PHP系统总被越权?5大核心校验机制必须掌握

第一章:为什么你的低代码PHP系统总被越权?在低代码开发盛行的今天,许多PHP系统通过可视化拖拽快速构建业务模块,但随之而来的安全问题日益突出,尤其是越权访问。开发者往往误以为“功能上线即安全”,却忽略…

作者头像 李华