微軟開源 Python 自動化神器 Playwright

最近,微軟開源了一個項目叫「playwright-python」,這個項目是針對 Python 語言的純自動化工具,它能夠經過單個API自動執行Chromium,Firefox和WebKit瀏覽器,連代碼都不用寫,就能實現自動化功能。javascript

相比測試工具 selenium 來講,playwright-python 簡直是小白們的神器。html

Playwright真的適用於Python嗎?答案是確定的,微軟對於適用於Python的Playwright已準備就緒。可能會發生API重大更改。 但大機率是這種狀況不會發生,微軟還表示僅在他們知道它能夠改善您使用新庫的體驗時,纔會可能這樣作。不過微軟也提醒尚不支持特定於供應商的API的某些極端狀況,例如收集Chromium跟蹤,覆蓋率報告等。java

1. Playwright介紹

Playwright是一個強大的Python庫,僅用一個API便可自動執行ChromiumFirefoxWebKit等主流瀏覽器自動化操做,並同時支持以無頭模式、有頭模式運行。python

Playwright提供的自動化技術是綠色的、功能強大、可靠且快速,支持LinuxMac以及Windows操做系統。git

2. Playwright使用

安裝

Playwright的安裝很是簡單,兩步走。github

安裝playwright庫
pip install playwright
安裝瀏覽器驅動文件(安裝過程稍微有點慢)
python -m playwright install
複製代碼

上面兩個pip操做分別安裝:web

  • 安裝Playwright依賴庫,須要Python3.7+
  • 安裝Chromium、Firefox、WebKit等瀏覽器的驅動文件

錄製

使用Playwright無需寫一行代碼,咱們只需手動操做瀏覽器,它會錄製咱們的操做,而後自動生成代碼腳本。瀏覽器

下面就是錄製的命令codegen,僅僅一行。less

命令行鍵入 --help 可看到全部選項
python -m playwright codegen
複製代碼

codegen的用法能夠使用--help查看,若是簡單使用就是直接在命令後面加上url連接,若是有其餘須要能夠添加optionsiphone

python -m playwright codegen --help
Usage: index codegen [options] [url]


open page and generate code for user actions


Options:
  -o, --output <file name>  saves the generated script to a file
  --target <language>       language to use, one of javascript, python, python-async, csharp (default: "python")
  -h, --help                display help for command


Examples:


  $ codegen
  $ codegen --target=python
  $ -b webkit codegen https://example.com

複製代碼

options含義:

  • -o:將錄製的腳本保存到一個文件
  • --target:規定生成腳本的語言,有JSPython兩種,默認爲Python
  • -b:指定瀏覽器驅動

好比,我要在baidu.com搜索,用chromium驅動,將結果保存爲my.pypython文件。

python -m playwright codegen --target python -o 'my.py' -b chromium https://www.baidu.com
複製代碼

命令行輸入後會自動打開瀏覽器,而後能夠看見在瀏覽器上的一舉一動都會被自動翻譯成代碼,以下所示。

結束後自動關閉瀏覽器,保存生成的自動化腳本到py文件。

from playwright import sync_playwright


def run(playwright):
browser = playwright.chromium.launch(headless=False)
context = browser.newContext()

# Open new page
page = context.newPage()


page.goto("https://www.baidu.com/")


page.click("input[name="wd"]")


page.fill("input[name="wd"]", "jingdong")


page.click("text="京東"")

# Click //a[normalize-space(.)='京東JD.COM官網 多快好省 只爲品質生活']
with page.expect_navigation():
    with page.expect_popup() as popup_info:
        page.click("//a[normalize-space(.)='京東JD.COM官網 多快好省 只爲品質生活']")
    page1 = popup_info.value
# ---------------------
context.close()
browser.close()
with sync_playwright() as playwright:
run(playwright

此外,playwright還提供了同步和異步的API接口,文檔以下。

連接: https://microsoft.github.io/playwright-python/index.html

同步

下面示例代碼:依次打開三個瀏覽器,前往baidu搜索,截圖後退出。

from playwright import sync_playwright
with sync_playwright() as p:
for browser_type in [p.chromium, p.firefox, p.webkit]:
    browser = browser_type.launch()
    page = browser.newPage()
    page.goto('https://baidu.com/')
    page.screenshot(path=f'example-{browser_type.name}.png')
    browser.close()
    複製代碼

異步

異步操做可結合asyncio同時進行三個瀏覽器操做。

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()
        page = await browser.newPage()
        await page.goto('http://baidu.com/')
        await page.screenshot(path=f'example-{browser_type.name}.png')
        await browser.close()
        asyncio.get_event_loop().run_until_complete(main())
       複製代碼

移動端

更厲害的是,playwright還可支持移動端的瀏覽器模擬。 下面是官方文檔提供的一段代碼,模擬在給定地理位置上手機iphone 11 pro上的Safari瀏覽器,首先導航到maps.google.com,而後執行定位並截圖。

from playwright import sync_playwright
with sync_playwright() as p:
iphone_11 = p.devices['iPhone 11 Pro']
browser = p.webkit.launch(headless=False)
context = browser.newContext(
    **iphone_11,
    locale='en-US',
    geolocation={ 'longitude': 12.492507, 'latitude': 41.889938 },
    permissions=['geolocation']
)
page = context.newPage()
page.goto('https://maps.google.com')
page.click('text="Your location"')
page.screenshot(path='colosseum-iphone.png')
browser.close()
複製代碼

另外,還能夠配合pytest插件一塊兒使用,感興趣能夠本身試一下。

3. 總結

playwright相比已有的自動化測試工具備不少優點,好比:

  • 跨瀏覽器,支持Chromium、Firefox、WebKit
  • 跨操做系統,支持Linux、Mac、Windows
  • 可提供錄製生成代碼功能,解放雙手
  • 可用於移動端
  • 在JavaScript,TypeScript,Python,C#和Java都可使用Playwright API。

如今playwright 已經更新到了 1.7.0 版本,目前存在的缺點就是生態和文檔還不是很是完備,好比沒有API中文文檔、沒有較好的教程和示例供學習。不過相信,隨着知道的人愈來愈多,將來會愈來愈好。

GitHub連接: https://github.com/microsoft/playwright-python
傳送門: https://playwright.dev/
開源組織:Microsoft

image.png

相關文章
相關標籤/搜索