微軟開源 Python 自動(dòng)化神器 Playwright
最近,微軟開源了一個(gè)項(xiàng)目叫「playwright-python」,作為一個(gè)興起項(xiàng)目,出現(xiàn)后受到了大家熱烈的歡迎,那它到底是什么樣的存在呢?今天為你介紹一下這個(gè)傳說(shuō)中的小白神器。

Playwright 是針對(duì) Python 語(yǔ)言的純自動(dòng)化工具,它可以通過(guò)單個(gè)API自動(dòng)執(zhí)行 Chromium,F(xiàn)irefox 和 WebKit 瀏覽器,連代碼都不用寫,就能實(shí)現(xiàn)自動(dòng)化功能。
雖然測(cè)試工具 selenium 具有完備的文檔,但是其學(xué)習(xí)成本讓一眾小白們望而卻步,對(duì)比之下 playwright-python 簡(jiǎn)直是小白們的神器。
Playwright真的適用于Python嗎?答案是肯定的,微軟對(duì)于適用于Python的Playwright已準(zhǔn)備就緒。可能會(huì)發(fā)生API重大更改。但大概率是這種情況不會(huì)發(fā)生,微軟還表示僅在他們知道它可以改善您使用新庫(kù)的體驗(yàn)時(shí),才會(huì)可能這樣做。不過(guò)微軟也提醒尚不支持特定于供應(yīng)商的API的某些極端情況,例如收集Chromium跟蹤,覆蓋率報(bào)告等。
1、Playwright介紹
Playwright是一個(gè)強(qiáng)大的Python庫(kù),僅用一個(gè)API即可自動(dòng)執(zhí)行Chromium、Firefox、WebKit等主流瀏覽器自動(dòng)化操作,并同時(shí)支持以無(wú)頭模式、有頭模式運(yùn)行。
Playwright提供的自動(dòng)化技術(shù)是綠色的、功能強(qiáng)大、可靠且快速,支持Linux、Mac以及Windows操作系統(tǒng)。
還有朋友這么夸:這個(gè)項(xiàng)目作為針對(duì) Python 語(yǔ)言純自動(dòng)化的工具,解放了代碼,實(shí)現(xiàn)了自動(dòng)化功能,我們來(lái)看看怎么用它吧。
2、Playwright使用
安裝
Playwright的安裝非常簡(jiǎn)單,兩步解決。
安裝playwright庫(kù)
pip?install?playwright
安裝瀏覽器驅(qū)動(dòng)文件(安裝過(guò)程稍微有點(diǎn)慢)
python?-m?playwright?install
復(fù)制代碼
上面兩個(gè)pip操作分別安裝:
-
安裝Playwright依賴庫(kù),需要Python3.7+ -
安裝Chromium、Firefox、WebKit等瀏覽器的驅(qū)動(dòng)文件
錄制
命令行鍵入?--help?可看到所有選項(xiàng)
python?-m?playwright?codegen
復(fù)制代碼
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
復(fù)制代碼
-
-o:將錄制的腳本保存到一個(gè)文件 -
--target:規(guī)定生成腳本的語(yǔ)言,有JS和Python兩種,默認(rèn)為Python -
-b:指定瀏覽器驅(qū)動(dòng)
python?-m?playwright?codegen?--target?python?-o?'my.py'?-b?chromium?https://www.baidu.com
復(fù)制代碼

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官網(wǎng)?多快好省?只為品質(zhì)生活']
with?page.expect_navigation():
????with?page.expect_popup()?as?popup_info:
????????page.click("http://a[normalize-space(.)='京東JD.COM官網(wǎng)?多快好省?只為品質(zhì)生活']")
????page1?=?popup_info.value
#?---------------------
context.close()
browser.close()
with?sync_playwright()?as?playwright:
run(playwright
鏈接:https://microsoft.github.io/playwright-python/index.html
同步
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()
????復(fù)制代碼
異步
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())
???????復(fù)制代碼
移動(dòng)端
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()
復(fù)制代碼
3、總結(jié)
支持所有瀏覽器的
-
在Chromium,F(xiàn)irefox和WebKit上進(jìn)行測(cè)試。Playwright擁有適用于所有現(xiàn)代瀏覽器的完整API覆蓋,包括Google Chrome和Microsoft Edge(帶有Chromium),Apple Safari(帶有WebKit)和Mozilla Firefox。 -
跨平臺(tái)的WebKit測(cè)試。使用Playwright,使用適用于Windows,Linux和macOS的WebKit構(gòu)建,測(cè)試您的應(yīng)用程序在Apple Safari中的行為。在本地和CI上進(jìn)行測(cè)試。 -
測(cè)試手機(jī)。使用設(shè)備仿真在移動(dòng)Web瀏覽器中測(cè)試您的自適應(yīng)Web應(yīng)用程序。 -
無(wú)報(bào)文頭與有報(bào)文頭。Playwright支持所有瀏覽器和所有平臺(tái)的無(wú)頭(無(wú)瀏覽器UI)和有頭(有瀏覽器UI)模式。有報(bào)文頭模式適用于調(diào)試,而無(wú)報(bào)文頭適用于CI / cloud執(zhí)行。
擁有快速可靠的執(zhí)行
- 自動(dòng)等待APIs。Playwright交互會(huì)自動(dòng)等待直到元素準(zhǔn)備就緒。這樣可以提高可靠性并簡(jiǎn)化測(cè)試編寫流程。
- 無(wú)超時(shí)自動(dòng)化。Playwright會(huì)接收瀏覽器信號(hào),例如網(wǎng)絡(luò)請(qǐng)求,頁(yè)面導(dǎo)航和頁(yè)面加載事件,以消除導(dǎo)致睡眠中斷的煩惱。
- 與瀏覽器上下文保持并行。對(duì)于多個(gè)并行孤立的瀏覽器上下文可執(zhí)行環(huán)境重復(fù)使用一個(gè)單獨(dú)的瀏覽器實(shí)例。
- 彈性元素選擇器。Playwright可以依靠面向用戶的字符串(例如文本內(nèi)容和可訪問(wèn)性標(biāo)簽)來(lái)選擇元素。這些字符串比緊耦合到DOM結(jié)構(gòu)的選擇器更具彈性。
擁有強(qiáng)大的自動(dòng)化功能
- 多個(gè)域,頁(yè)面和框架。Playwright是一種進(jìn)程外自動(dòng)化驅(qū)動(dòng)程序,不受頁(yè)面內(nèi)JavaScript執(zhí)行范圍的限制,并且可以自動(dòng)執(zhí)行具有多個(gè)頁(yè)面的方案。
- 強(qiáng)大的網(wǎng)絡(luò)控制。Playwright引入上下文范圍的網(wǎng)絡(luò)攔截以便進(jìn)行終止或者模擬網(wǎng)絡(luò)請(qǐng)求。
- 現(xiàn)代網(wǎng)絡(luò)功能。Playwright通過(guò)插入陰的選擇器,地理位置,權(quán)限,Web Worker和其他現(xiàn)代Web API支持Web組件。
- 涵蓋所有場(chǎng)景的能力。支持文件下載和上傳,進(jìn)程外iframe,原生輸入事件,甚至是深色模式。
但它也有局限性
- 舊版Edge和IE11支持。Playwright不支持舊版Microsoft Edge或IE11(棄用通知)。支持新的Microsoft Edge(在Chromium上)。
- Java語(yǔ)言綁定:Playwright API目前無(wú)法在Java或Ruby中使用。這是暫時(shí)的限制,因?yàn)镻laywright旨在支持任何語(yǔ)言的綁定。
- 在真實(shí)的移動(dòng)設(shè)備上進(jìn)行測(cè)試:Playwright使用桌面瀏覽器來(lái)模擬移動(dòng)設(shè)備。
GitHub鏈接:https://github.com/microsoft/playwright-python
傳送門:https://playwright.dev/開源組織:Microsoft