python palywright庫基本使用
更新時間:2021年01月21日 10:44:11 作者:測神
這篇文章主要介紹了python palywright庫的基本使用,幫助大家更好的理解和使用python,感興趣的朋友可以了解下
開源方:微軟
安裝:pip install playwright;python -m playwright install
特點:自動化腳本錄制;有同步、異步api
生成代碼指令:python -m playwright codegen
其他:需要Python 3.7及以上;官方api為node版本,python版本待補充
同步:關(guān)鍵字為: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()
異步:關(guān)鍵字為: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")
執(zhí)行 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()
中斷網(wǎng)絡(luò)請求
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_()
記錄并繼續(xù)所有網(wǎng)絡(luò)請求
page.route('**', lambda route, request: log_and_continue_request(route, request)) page.goto('http://todomvc.com') browser.close()
以上就是python palywright庫基本使用的詳細內(nèi)容,更多關(guān)于python palywright庫的資料請關(guān)注腳本之家其它相關(guān)文章!
您可能感興趣的文章:
- Python+unittest+requests+excel實現(xiàn)接口自動化測試框架
- Python接口自動化測試框架運行原理及流程
- python+appium+yaml移動端自動化測試框架實現(xiàn)詳解
- Python+unittest+requests 接口自動化測試框架搭建教程
- Python實現(xiàn)http接口自動化測試的示例代碼
- python自動化測試三部曲之request+django實現(xiàn)接口測試
- Python3+RIDE+RobotFramework自動化測試框架搭建過程詳解
- jenkins+python自動化測試持續(xù)集成教程
- python利用Excel讀取和存儲測試數(shù)據(jù)完成接口自動化教程
- 使用python+poco+夜神模擬器進行自動化測試實例
- Python+Appium實現(xiàn)自動化測試的使用步驟
- python selenium自動化測試框架搭建的方法步驟
相關(guān)文章
如何基于Python代碼實現(xiàn)高精度免費OCR工具
這篇文章主要介紹了如何基于Python代碼實現(xiàn)高精度免費OCR工具,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2020-06-06關(guān)于Python3 lambda函數(shù)的深入淺出
今天小編就為大家分享一篇關(guān)于Python3 lambda函數(shù)的深入淺出,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-11-11利用Python腳本寫端口掃描器socket,python-nmap
這篇文章主要介紹了利用Python腳本寫端口掃描器socket,python-nmap,文章圍繞主題展開詳細介紹,具有一定的參考價值,需要的小伙伴可以參考一下2022-07-07