基于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

相关推荐
焦糖玛奇朵婷几秒前
盲盒小程序开发|解锁开箱新体验[特殊字符]
大数据·开发语言·程序人生·小程序·软件需求
1104.北光c°1 分钟前
基于Canal + Kafka的高可用关注系统:一主多从关系链
java·开发语言·笔记·分布式·程序人生·kafka·一主多从
2501_924952691 分钟前
Python深度学习入门:TensorFlow 2.0/Keras实战
jvm·数据库·python
Mem0rin2 分钟前
[Java]异常及其处理
java·开发语言
HelloReader2 分钟前
Qt Quick vs Qt Widgets如何选择适合你的 UI 技术路线(五)
前端
2401_891482174 分钟前
Python多线程与多进程:如何选择?(GIL全局解释器锁详解)
jvm·数据库·python
2401_851272994 分钟前
用Python实现自动化的Web测试(Selenium)
jvm·数据库·python
cmd5 分钟前
吃透 ES6 Generator:yield/next/yield* 核心用法详解
前端·javascript
2401_846341656 分钟前
调试技巧与核心转储分析
开发语言·c++·算法
我叫黑大帅6 分钟前
🎯 DOM 事件:onclick VS addEventListener('click')区别
前端·javascript·面试