基于aardio web.view2库和python playwright包的内嵌浏览器自动化操作

通过cdp协议可以实现playwright操控webview。

新建Python窗口工程

修改pip.aardio

修改pip.aardio,并执行,安装playwright。

cpp 复制代码
//安装模块
import process.python.pip;
//process.python.path = "python.exe";

/*
安装模块。
参数可以用一个字符串指定多个 pip 参数,参数以空格分开。
也可以用多个 aardio 参数指定多个 pip 参数,aardio 自动合并所有参数并自动处理转义。
*/
process.python.pip("install playwright");

//如果指定的模块未安装,则调用 pip 安装
// process.python.pip.require("请指定要安装的模块名称");

console.pause();

实现playwright操控webview

cpp 复制代码
import win.ui;
/*DSG{{*/
mainForm = win.form(text="playwright测试";right=957;bottom=708)
mainForm.add()
/*}}*/

import web.view2;
//第4个参数为0则开启远程端口,取空闲端口号
wb = web.view2(mainForm,,0);

import string.template

html1 = `
from playwright.sync_api import Playwright, sync_playwright, expect

def run(playwright: Playwright) -> None:

    # 使用chromium.connect_over_cdp远程连接webview
    browser = playwright.chromium.connect_over_cdp("http://127.0.0.1:${port}")
    context = browser.contexts[0]
    page = context.pages[0]
    page.goto("https://www.baidu.com/")
    page.locator("#kw").click()
    page.locator("#kw").fill("附加webview测试")
    page.get_by_role("button", name="百度一下").click()


with sync_playwright() as playwright:
    run(playwright)
    
`
html = string.template(html1).format(
    port = wb.remoteDebuggingPort;
)


import process.python;

process.python.version = "3.9.13";
process.python.win32 = true;

process.python.exec(html);

mainForm.show();
return win.loopMessage();

相关链接

https://mp.weixin.qq.com/s/F6sLUiY0v0YWyYDYSO2L4Q

相关推荐
卡提西亚19 小时前
C++笔记-24-文件读写操作
开发语言·c++·笔记
How_doyou_do19 小时前
模态框的两种管理思路
java·服务器·前端
snakecy19 小时前
树莓派学习资料共享
大数据·开发语言·学习·系统架构
我的xiaodoujiao19 小时前
使用 Python 语言 从 0 到 1 搭建完整 Web UI自动化测试学习系列 24--数据驱动--参数化处理 Excel 文件 1
python·学习·测试工具·pytest
Nebula_g20 小时前
C语言应用实例:学生管理系统1(指针、结构体综合应用,动态内存分配)
c语言·开发语言·学习·算法·基础
snow@li20 小时前
前端:前端/浏览器 可以录屏吗 / 实践 / 录制 Microsoft Edge 标签页、应用窗口、整个屏幕
前端·浏览器录屏·前端录屏·web录屏
开心-开心急了20 小时前
关于Flutter与Qt for python 的一些技术、开源、商用等问题
开发语言·python·qt·flutter
友友马20 小时前
『 QT 』按钮类控件属性解析
开发语言·数据库·qt
李贺梖梖20 小时前
CSS学习
前端·css