drissionpage-dev
SKILL.md
DrissionPage Dev
Overview
Use this skill to build reliable DrissionPage automation in Python by following a consistent workflow and consulting the bundled official docs in references/docs/.
Preferences
- Do not use DrissionPage native wait APIs for long “query waiting” flows; instead poll static HTML (
tab.html/ snapshot) and parse withparsel.Selector(or an equivalent HTML parser) to detect state transitions. - Do not rely on DrissionPage native “ready” checks when they are unreliable; instead implement readiness checks by parsing the static DOM for stable page markers (e.g., main content mounted, captcha/overlay shown or gone).
Workflow
1) Clarify the goal and choose a mode
- Prefer
SessionPagewhen the target data is available via HTTP responses and JS rendering is not required. - Prefer
ChromiumPagewhen you must run a real Chromium browser (JS rendering, complex login, anti-bot flows, file dialogs, etc.). - Prefer
WebPagewhen you need both browser control and packet sending/receiving (mode switching) in the same object.
Docs:
references/docs/🌏 导入 - DrissionPage官网.md(core classes and import paths)references/docs/⭐ 模式切换 - DrissionPage官网.mdandreferences/docs/🗺️ 模式切换 - DrissionPage官网.md(mode switching)
2) Create objects and configure startup
- Use
ChromiumOptionsfor browser startup parameters; remember: options only apply when launching the browser, not when attaching to an existing one. - Use
SessionOptionsto configureSessionPage/WebPages-mode. - Use
Settingsfor global behavior (e.g., whether to raise when an element is not found).
Docs:
references/docs/🌏 导入 - DrissionPage官网.mdreferences/docs/🛩️ 创建页面对象 - DrissionPage官网.mdreferences/docs/🛩️ 启动配置 - DrissionPage官网.mdreferences/docs/⚙️ 全局设置 - DrissionPage官网.md
3) Locate elements with the official syntax
- Use the locating syntax docs as the source of truth; avoid guessing selector formats.
- When refactoring, keep locators centralized and prefer explicit waits over sleeps.
Docs:
references/docs/🔦 概述 - DrissionPage官网.mdreferences/docs/🔦 定位语法 - DrissionPage官网.mdreferences/docs/🔦 语法速查表 - DrissionPage官网.mdreferences/docs/🔦 相对定位 - DrissionPage官网.mdreferences/docs/🔦 在结果列表中筛选 - DrissionPage官网.md
4) Interact, wait, and handle frames/tabs
- Use the dedicated wait APIs for stability; treat timeouts as first-class.
- Handle
iframeexplicitly. - Use tab management APIs when working with new windows/tabs.
Docs:
references/docs/🛰️ 元素交互 - DrissionPage官网.mdreferences/docs/🛰️ 等待 - DrissionPage官网.mdreferences/docs/🛰️ iframe 操作 - DrissionPage官网.mdreferences/docs/🛰️ 标签页管理 - DrissionPage官网.md
5) Downloads, uploads, and network debugging
- For downloads, use the documented
download/ browser download flows. - For uploads, use the upload docs and prefer stable file selection approaches.
- For debugging flaky flows, use screenshots/recording, console logs, and network listening.
Docs:
references/docs/⭐ 下载文件 - DrissionPage官网.mdreferences/docs/⤵️ download方法 - DrissionPage官网.mdreferences/docs/⤵️ 浏览器下载 - DrissionPage官网.mdreferences/docs/🛰️ 上传文件 - DrissionPage官网.mdreferences/docs/🛰️ 截图和录像 - DrissionPage官网.mdreferences/docs/🛰️ 获取控制台信息 - DrissionPage官网.mdreferences/docs/🛰️ 监听网络数据 - DrissionPage官网.md
6) Exceptions and troubleshooting
- Catch and handle DrissionPage exceptions intentionally; do not blanket-catch everything.
- Use the FAQ when behavior differs from expectations.
Docs:
references/docs/⚙️ 异常的使用 - DrissionPage官网.mdreferences/docs/❓ 常见问题 - DrissionPage官网.md
Quick search recipes (for Codex)
-
Search the bundled docs by keyword:
rg -n -S "<keyword>" references/docs- For case-insensitive English terms:
rg -n -i "<keyword>" references/docs
-
When the API name is known, search by identifier:
rg -n -S "\\bChromiumPage\\b" references/docsrg -n -S "\\bSessionPage\\b" references/docs
Minimal starter snippet
Use the docs as the source of truth for parameters and return values.
from DrissionPage import ChromiumPage, WebPage, SessionPage
from DrissionPage import ChromiumOptions, SessionOptions
from DrissionPage.common import Settings
Weekly Installs
15
Repository
d0ublecl1ck/dri…page-devFirst Seen
Feb 11, 2026
Security Audits
Installed on
opencode15
github-copilot15
codex15
amp15
kimi-cli15
gemini-cli15