news 2026/6/10 17:18:38

Requestium - 将Requests和Selenium合并在一起的自动化测试工具

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Requestium - 将Requests和Selenium合并在一起的自动化测试工具

Requests 是 Python 的第三方库,主要用于发送http请求,常用于接口自动化测试等。

Selenium 是一个用于 Web 应用程序的自动化测试工具。Selenium 测试直接运行在浏览器中,就像真正的用户在操作一样。

本篇介绍一款将 Requests 和 Selenium 结合在一起的自动化测试工具 - Requestium

简介

Requestium 是一个 Python 库,它将 Requests、Selenium 和 Parsel 的功能合并为一个用于自动化 web 操作的集成工具。

该库是为编写 web 自动化脚本而创建的,这些脚本主要使用请求编写,但能够在维护会话的同时,无缝切换到网站中 JavaScript 密集部分的 Selenium。

Requestium 为 Requests 和 Selenium 添加了独立的改进,并且每一个新功能都经过了延迟评估,因此即使编写只使用 Requests 或 Selenium 的脚本,它也很有用。

特点:

1、在维护当前 web 会话的同时,启用请求会话和 Selenium web 驱动程序之间的切换。

2、将 Parsel 的解析器集成到库中,使 xpath、css 和 regex 的编写更加简洁。

3、改进了 Selenium 对动态加载元素的处理。

4、使 Selenium 中的 cookie 处理更加灵活。

5、使 Selenium 中的点击元素更加可靠。

6、本机支持 Chromedriver,并添加自定义网络驱动程序。

安装:

pip install requestium

如果你使用 Requestium 的 Selenium 部分,例如 Chromedriver,那么你应该下载 Selenium Web 驱动程序。

快速上手

首先,像处理请求一样创建一个会话,如果使用 web 驱动程序,可以选择添加参数。
#!/usr/bin/env python

# -*- coding: utf-8 -*- # 111 from requestium import Session, Keys options = {'arguments': ['headless']} s = Session(webdriver_path='./chromedriver', default_timeout=15, webdriver_options=options)

由于无头模式很常见,因此有一个快捷方式可以指定 headless=True。

#!/usr/bin/env python # -*- coding: utf-8 -*- # 111 from requestium import Session, Keys s = Session(webdriver_path='./chromedriver' headless=True)

你也可以在 Requestium 之外创建一个 Selenium 网络驱动程序,并使用它:

#!/usr/bin/env python # -*- coding: utf-8 -*- # 111 from selenium import webdriver from requestium import Session, Keys firefox_driver = webdriver.Firefox() s = Session(driver=firefox_driver)

你不需要解析响应,当调用 xpath,css 或 re 时,它会自动完成。

#!/usr/bin/env python # -*- coding: utf-8 -*- # 111 title = s.get('http://samplesite.com').xpath('//title/text()').extract_first(default='Default Title')

与 Python 的标准 re 模块相比,正则表达式需要更少的代码。

#!/usr/bin/env python # -*- coding: utf-8 -*- # 111 response = s.get('http://samplesite.com/sample_path') # Extracts the first match identifier = response.re_first(r'ID_\d\w\d', default='ID_1A1') # Extracts all matches as a list users = response.re(r'user_\d\d\d')

你可以切换到使用 Selenium Webdriver 来运行任何 js 代码。

#!/usr/bin/env python # -*- coding: utf-8 -*- # s.transfer_session_cookies_to_driver() s.driver.get('http://www.samplesite.com/sample/process')

最后,你可以切换回使用 Requests。

#!/usr/bin/env python # -*- coding: utf-8 -*- # s.transfer_driver_cookies_to_session() s.post('http://www.samplesite.com/sample2', data={'key1': 'value1'})

等待元素

ensure_element_by_ 方法等待元素在浏览器中加载,并在加载后立即返回。它以 Selenium的 find_element_by_ 方法命名(如果找不到元素,它们会立即引发异常)。

Requestium 可以等待一个元素处于以下任何状态:

存在(默认)

可点击

看得见的

不可见(可用于等待加载… GIF 消失等)

这些方法对于单页面 Web 应用程序非常有用,其中站点动态地更改其元素。我们通常最终完全用 ensure_element_by_ 调用替换我们的 find_element_by_ 调用,因为它们更灵活。使用这些方法获取的元素具有新的 ensure_click 方法,这使得点击不太容易失败。这有助于解决 Selenium 点击的许多问题。

#!/usr/bin/env python # -*- coding: utf-8 -*- # s.driver.ensure_element_by_xpath("//li[@class='b1']", state='clickable', timeout=5).ensure_click() # === We also added these methods named in accordance to Selenium's api design === ensure_element_by_id ensure_element_by_name ensure_element_by_link_text ensure_element_by_partial_link_text ensure_element_by_tag_name ensure_element_by_class_name ensure_element_by_css_selector

添加 Cookie

ensure_add_cookie 方法使得添加 Cookie 更加稳健。Selenium 需要浏览器在能够添加 Cookie 之前处于 Cookie 的域中,此方法为此提供了几种解决方法。如果浏览器不在 Cookie 域中,它会先获取域然后再添加 Cookie。它还允许你在添加 Cookie 之前覆盖域,并避免执行此 GET。域可以被覆盖为 ’’,这将把 Cookie 的域设置为驱动程序当前所在的任何域。如果无法添加 cookie,它会尝试使用限制性较小的域(例如:home.site.com -> site.com)进行添加,然后在失败之前。

#!/usr/bin/env python # -*- coding: utf-8 -*- # cookie = {"domain": "www.site.com", "secure": false, "value": "sd2451dgd13", "expiry": 1516824855.759154, "path": "/", "httpOnly": true, "name": "sessionid"} s.driver.ensure_add_cookie(cookie, override_domain='')

使用 Requestium 示例

#!/usr/bin/env python # -*- coding: utf-8 -*- # from requestium import Session, Keys # If you want requestium to type your username in the browser for you, write it in here: reddit_user_name = '' s = Session('./chromedriver', default_timeout=15) s.driver.get('http://reddit.com') s.driver.find_element_by_xpath("//a[@href='https://www.reddit.com/login']").click() print('Waiting for elements to load...') s.driver.ensure_element_by_class_name("desktop-onboarding-sign-up__form-toggler", state='visible').click() if reddit_user_name: s.driver.ensure_element_by_id('user_login').send_keys(reddit_user_name) s.driver.ensure_element_by_id('passwd_login').send_keys(Keys.BACKSPACE) print('Please log-in in the chrome browser') s.driver.ensure_element_by_class_name("desktop-onboarding__title", timeout=60, state='invisible') print('Thanks!') if not reddit_user_name: reddit_user_name = s.driver.xpath("//span[@class='user']//text()").extract_first() if reddit_user_name: s.transfer_driver_cookies_to_session() response = s.get("https://www.reddit.com/user/{}/".format(reddit_user_name)) cmnt_karma = response.xpath("//span[@class='karma comment-karma']//text()").extract_first() reddit_golds_given = response.re_first(r"(\d+) gildings given out") print("Comment karma: {}".format(cmnt_karma)) print("Reddit golds given: {}".format(reddit_golds_given)) else: print("Couldn't get user name")

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

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

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

集团企业人力资源(HR)数字化转型规划【43页PPT】

在当今快速发展的数字化时代,企业人力资源管理正经历着前所未有的转型。本文档详细介绍了集团企业在人力资源领域进行数字化转型的战略规划和具体实施步骤,旨在通过先进的数字化手段,将传统的人力资源管理提升至人力资本管理的新高度。一、数…

作者头像 李华
网站建设 2026/6/9 21:51:43

一口气讲清楚:AGI、RAG、AIGC,非常详细收藏我这一篇就够了

看了很多关于AI大模型的文章,发现其中高频出现了一些专业名词,比如AGI、RAG、AIGC等。看着很高大上,但这些名词到底是什么意思,又预示着什么,普通人很难通俗易懂的理解。 这篇文章,我尝试用通俗易懂的语言&…

作者头像 李华
网站建设 2026/6/10 11:43:13

网站做了半年,百度还不收录?这5个原因太扎心

网站做了很久,为什么百度就是不收录?1分钟告诉你最常见的 5 个原因!原因一:没提交百度收录网站上线了,没去站长平台提交收录,搜索引擎根本不知道你的网站上线了。原因二:页面太少,没…

作者头像 李华