python palywright库基本使用
作者:测神
这篇文章主要介绍了python palywright库的基本使用,帮助大家更好的理解和使用python,感兴趣的朋友可以了解下
开源方:微软
安装:pip install playwright;python -m playwright install
特点:自动化脚本录制;有同步、异步api
生成代码指令:python -m playwright codegen
其他:需要Python 3.7及以上;官方api为node版本,python版本待补充
同步:关键字为:sync_playwright
from time import sleep from playwright import sync_playwright with sync_playwright() as p: for browser_type in [p.chromium, p.firefox, p.webkit]: browser = browser_type.launch(headless=False) # 默认无头,这样为有头模式 page = browser.newPage() page.goto('http://baidu.com') page.fill("input[name=\"wd\"]", "AirPython") with page.expect_navigation(): page.press("input[name=\"wd\"]", "Enter") page.waitForSelector("text=百度热榜") page.screenshot(path=f'example-{browser_type.name}.png') sleep(5) browser.close()
异步:关键字为:async_playwright
import asyncio from playwright import async_playwright async def main(): async with async_playwright() as p: for browser_type in [p.chromium, p.firefox, p.webkit]: browser = await browser_type.launch(headless=False) page = await browser.newPage() await page.goto('http://baidu.com') await page.fill("input[name=\"wd\"]", "AirPython") await page.press("input[name=\"wd\"]", "Enter") await page.waitForSelector("text=百度热榜") await page.screenshot(path=f'example-{browser_type.name}.png') await browser.close() asyncio.get_event_loop().run_until_complete(main())
集成 pytest 测试
@pytest.fixture(scope="session") def test_playwright_is_visible_on_google(page): page.goto("https://www.google.com") page.type("input[name=q]", "Playwright GitHub") page.click("input[type=submit]") page.waitForSelector("text=microsoft/Playwright")
执行 JS 代码
from playwright import sync_playwright with sync_playwright() as p: browser = p.firefox.launch() page = browser.newPage() page.goto('https://www.example.com/') dimensions = page.evaluate('''() => { return { width: document.documentElement.clientWidth, height: document.documentElement.clientHeight, deviceScaleFactor: window.devicePixelRatio } }''') print(dimensions) browser.close()
中断网络请求
from playwright import sync_playwright with sync_playwright() as p: browser = p.chromium.launch() page = browser.newPage() def log_and_continue_request(route, request): print(request.url) route.continue_()
记录并继续所有网络请求
page.route('**', lambda route, request: log_and_continue_request(route, request)) page.goto('http://todomvc.com') browser.close()
以上就是python palywright库基本使用的详细内容,更多关于python palywright库的资料请关注脚本之家其它相关文章!
您可能感兴趣的文章:
- Python+unittest+requests+excel实现接口自动化测试框架
- Python接口自动化测试框架运行原理及流程
- python+appium+yaml移动端自动化测试框架实现详解
- Python+unittest+requests 接口自动化测试框架搭建教程
- Python实现http接口自动化测试的示例代码
- python自动化测试三部曲之request+django实现接口测试
- Python3+RIDE+RobotFramework自动化测试框架搭建过程详解
- jenkins+python自动化测试持续集成教程
- python利用Excel读取和存储测试数据完成接口自动化教程
- 使用python+poco+夜神模拟器进行自动化测试实例
- Python+Appium实现自动化测试的使用步骤
- python selenium自动化测试框架搭建的方法步骤