DrissionPage 一个替代selenium的pip --- 一个可以接管正在运行的chrome包

DrissionPage 一个替代selenium的pip包,持续更新

1、加载内容,并接管chrome浏览器

bash 复制代码
from DrissionPage import ChromiumPage, ChromiumOptions
page = ChromiumPage(addr_or_opts='127.0.0.1:9222')
print(page.title)

ul = page.eles('@id=form-submit')
for i in ul:
    print(i.text)
    
废话

DrissionPage 是一个基于 Selenium 的自动化测试框架,它简化了 Selenium 的使用过程,并且支持多种浏览器。下面是一段关于 DrissionPage 的学习笔记示例:


DrissionPage 学习笔记

1. 引言
  • 目的:了解和掌握 DrissionPage 的基本用法及优势。
  • 背景:Selenium 虽然功能强大,但代码复杂度较高,DrissionPage 则通过封装常用操作,提高了自动化脚本的开发效率。
2. 安装与配置
  • 安装

    bash 复制代码
    pip install drissionpage
  • 环境准备

    • 安装对应浏览器及其驱动程序(如 ChromeDriver)。
    • 设置环境变量,确保浏览器驱动可被访问。
3. 基本用法
  • 初始化浏览器

    python 复制代码
    from drissionpage import DrissionPage
    
    # 初始化浏览器实例
    page = DrissionPage(browser='chrome')
  • 打开网页

    python 复制代码
    page.get('https://www.example.com')
  • 元素定位

    • CSS 选择器

      python 复制代码
      element = page.locator_css('#element-id').wait()
    • XPath

      python 复制代码
      element = page.locator_xpath('//div[@id="element-id"]').wait()
  • 元素交互

    • 点击

      python 复制代码
      element.click()
    • 输入文本

      python 复制代码
      element.type('Hello, World!')
  • 关闭浏览器

    python 复制代码
    page.quit()
4. 高级特性
  • 页面等待

    python 复制代码
    page.wait_page_load()
  • 断言

    python 复制代码
    assert page.locator_css('#element-id').exists()
  • 截图

    python 复制代码
    page.screenshot('example.png')
5. 示例代码
python 复制代码
from drissionpage import DrissionPage

def test_example():
    page = DrissionPage(browser='chrome')

    try:
        page.get('https://www.example.com')
        page.wait_page_load()

        search_box = page.locator_css('#search-box').wait()
        search_box.type('test query')
        search_box.submit()

        results = page.locator_css('.search-result').wait_all()
        assert len(results) > 0

    finally:
        page.quit()

if __name__ == '__main__':
    test_example()
6. 总结
  • DrissionPage 通过提供简洁的 API 和封装机制,大大降低了使用 Selenium 进行 Web 自动化测试的难度。
  • 适合快速原型开发和日常测试任务。

相关推荐
a1117766 小时前
医院挂号预约系统(开源 Fastapi+vue2)
前端·vue.js·python·html5·fastapi
0思必得06 小时前
[Web自动化] Selenium处理iframe和frame
前端·爬虫·python·selenium·自动化·web自动化
摘星编程8 小时前
OpenHarmony + RN:Calendar日期选择功能
python
Yvonne爱编码8 小时前
JAVA数据结构 DAY3-List接口
java·开发语言·windows·python
一方_self8 小时前
了解和使用python的click命令行cli工具
开发语言·python
小芳矶8 小时前
Dify本地docker部署踩坑记录
python·docker·容器
2301_822366359 小时前
使用Scikit-learn构建你的第一个机器学习模型
jvm·数据库·python
小郎君。9 小时前
【无标题】
python
喵手10 小时前
Python爬虫实战:数据治理实战 - 基于规则与模糊匹配的店铺/公司名实体消歧(附CSV导出 + SQLite持久化存储)!
爬虫·python·数据治理·爬虫实战·零基础python爬虫教学·规则与模糊匹配·店铺公司名实体消岐
喵手10 小时前
Python爬虫实战:国际电影节入围名单采集与智能分析系统:从数据抓取到获奖预测(附 CSV 导出)!
爬虫·python·爬虫实战·零基础python爬虫教学·采集数据csv导出·采集国际电影节入围名单·从数据抓取到获奖预测