Python寫UI自動化之playwright(點擊操作)詳解
0. selector (必需)
類型: string
描述: CSS 選擇器或 XPath 表達式,用于定位要點擊的元素。
是必須提供的參數(shù),用于確定要點擊的元素。
1. modifiers(可選)
傳入一個列表,其中是鍵盤的按鍵操作,比如"Ctrl","Alt","Shift","win鍵"等
類型: Array<string>
描述: 一個字符串?dāng)?shù)組,用于指定要按下的修飾鍵??捎玫男揎楁I包括 "Shift", "Control", "Alt", "Meta"(代表 Command 鍵或 Windows 鍵)。
使用場景
模擬組合鍵點擊:如果需要模擬用戶同時按下 Shift 或 Control 鍵并點擊元素,可以使用 modifiers 參數(shù)。例如,模擬用戶按下 Ctrl 鍵并點擊鏈接以在新標(biāo)簽頁中打開鏈接。
模擬特殊操作:在某些情況下,需要模擬特殊的鍵盤操作。例如,在表格中按下 Ctrl 鍵并點擊單元格以選擇多個項。
from playwright.sync_api import Page def test_pw_click(page: Page): page.goto(url='https://www.baidu.com') page.locator('//input[@name="wd"]').fill("日歷") page.get_by_text('百度一下').click(modifiers=["Control"]) #Control、Alt、Shift、Meta
2. position(可選)
傳入一個字典,{"x":10, "y": 20 },表示點擊位置距離元素左上角的偏移量??梢杂胋ounding_box()方法先查看這個元素的width和height,再確定自己點擊位置要偏移多少,偏移量不能超過這個元素的寬高范圍。當(dāng)被操作元素被遮罩時,雖然playwright會自動尋找可點擊位置,但是這樣顯示指定點擊位置會更精確一些
類型: { x: number, y: number }
描述: 指定相對于元素左上角的點擊位置。x 和 y 分別表示水平和垂直偏移量。
使用場景: 需要在元素內(nèi)部的特定位置點擊時,可以使用 position 參數(shù)。這對于需要點擊元素內(nèi)的某個圖標(biāo)或按鈕的情況很有用。例如,如果有一個帶有下拉箭頭的按鈕,可能需要點擊箭頭而不是整個按鈕區(qū)域。
from playwright.sync_api import Page def test_pw_click(page: Page): page.goto(url='https://www.baidu.com') page.locator('//input[@name="wd"]').fill("翻譯") page.get_by_text('百度一下').click() # 獲取元素位置 page.get_by_text('百度首頁').bounding_box() # 返回示例:{'x': 1082, 'y': 24, 'width': 52, 'height': 24} # 表示這個元素在整個界面位置,以及元素本身的寬和高范圍大小 # 點擊元素的特定位置 page.click("#my-button", position={"x": 10, "y": 10})
3. button(可選)
可以模擬左鍵右鍵中間鍵點擊
類型: "left" | "right" | "middle"
描述: 指定要使用的鼠標(biāo)按鈕。默認值為 "left"。
使用場景: 需要模擬右鍵點擊或其他類型的鼠標(biāo)按鈕點擊時使用。例如模擬右鍵點擊來打開上下文菜單。
from playwright.sync_api import Page def test_pw_click(page: Page): page.goto(url='https://www.baidu.com') page.locator('//input[@name="wd"]').fill("翻譯") page.get_by_text('百度一下').click() page.get_by_text('百度首頁').click(button="right") #left左鍵 right右鍵 middle中鍵
4. click_count(可選)
傳點擊次數(shù),和delay參數(shù)結(jié)合使用
類型: number
描述: 指定點擊次數(shù)。默認為 1,可以設(shè)置為 2 來模擬雙擊。
使用場景: 需要模擬雙擊或其他次數(shù)的點擊時使用。例如,雙擊文件列表中的文件來打開它。
page.locator('//input[@id="su"]').click(click_count=3,delay=3_000)
雙擊還有另一個方便的方法dblclick(),括號中的參數(shù)跟click()類似:
page.locator('//input[@id="su"]').dblclick()
5. delay
類型: number
描述: 設(shè)置兩次點擊之間的延遲時間(毫秒)。默認為 0。
使用場景: 需要模擬用戶點擊時的自然延遲,比如在雙擊之間加入短暫的停頓,以模仿真實的用戶行為。
6. timeout(可選)
傳入超時時間
類型: number
描述: 設(shè)置最大等待時間(毫秒),超過此時間后將拋出超時錯誤。默認為 30000 毫秒(30 秒)。
使用場景: 當(dāng)你需要限制等待元素變得可點擊的時間。例如,在等待元素出現(xiàn)時,你可能不想等待太長時間。
page.get_by_text('#要點擊的元素').click(timeout=1_000) #超時時間,默認30s
7. force=True(可選)
表示playwright auto-waiting機制中,當(dāng)設(shè)置 force=True 時,即使元素被其他元素遮擋,Playwright 也會嘗試強制點擊該元素。這意味著即使有對話框或其他元素遮擋了目標(biāo)元素,Playwright 也會嘗試直接點擊目標(biāo)元素。
類型: bool
描述: 如果為 true,則強制點擊元素,即使它被遮擋。默認為 false。
使用場景: 當(dāng)元素被其他元素遮擋時,仍然需要點擊它。例如,如果一個按鈕被一個模態(tài)對話框遮擋,可能需要強制點擊該按鈕。
page.get_by_text('#需要點擊的元素').click(force=True)
8. trial=True(可選)
表示只進行playwright auto-waiting的等待而不進行click操作
類型: bool
描述: 如果為 true,則不執(zhí)行實際的點擊操作,而是僅嘗試查找元素并檢查是否可以點擊。默認為 false。
使用場景: 需要驗證元素是否可以點擊,但不執(zhí)行實際的點擊操作。例如,在測試準(zhǔn)備階段,你可能需要檢查頁面上的所有按鈕是否可點擊。
page.get_by_text('#要點擊的元素').click(trial=True) #點擊前檢查元素
9. no_wait_after(可選)
表示,一般情況下,如果click操作觸發(fā)了一個導(dǎo)航事件,那么pw會等待導(dǎo)航結(jié)束,但是這樣可能導(dǎo)致click一直未結(jié)束而失敗。這個就是為了避免這種情況發(fā)生。
類型: bool
描述: 如果為 true,則點擊后不等待頁面導(dǎo)航或資源加載完成。默認為 false。
使用場景: 當(dāng)點擊操作不會導(dǎo)致頁面重新加載,而只是觸發(fā)一些異步操作(如 AJAX 請求)時。例如,如果點擊按鈕只是更新頁面的一部分內(nèi)容而不刷新整個頁面。
page.get_by_text('#要點擊的元素').click(no_wait_after=True) #點擊后不等待頁面加載
總結(jié)一下,playwright的click操作有這么幾步:
1.Auto-waiting機制,自動等待元素到可以被成功點擊,除非設(shè)置了force=True
2.把元素滑動到可以被點擊的地方
3.合并modifiers中的按鍵進行點擊操作,除非設(shè)置了trial=True
4.等待可能的導(dǎo)航結(jié)束,除非設(shè)置了no_wait_after=True
注意事項
在使用 click 方法時,確保元素是可見的并且在頁面上是可交互的。
使用 position 參數(shù)時,請確保指定的坐標(biāo)位于元素的有效范圍內(nèi)。
使用 noWaitAfter 參數(shù)時要注意,如果不等待頁面加載完成,可能會影響后續(xù)的測試步驟。
使用 timeout 參數(shù)時要合理設(shè)置,過短的超時時間可能導(dǎo)致測試失敗,過長則可能降低測試效率。
熟悉click()方法的這些參數(shù),我們可以根據(jù)需求精確地控制點擊行為,使自動化測試更加可靠和高效。
總結(jié)
到此這篇關(guān)于Python寫UI自動化之playwright的文章就介紹到這了,更多相關(guān)Python自動化playwright點擊操作內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Python中RSA加解密與數(shù)字簽名技術(shù)的使用
本文將詳細介紹 RSA 數(shù)字簽名的原理、實現(xiàn)步驟,以及如何通過 Python 的 rsa 庫完成公鑰私鑰生成、數(shù)字簽名和認證,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2025-03-03Flask實現(xiàn)的接口響應(yīng)中存在中文時接口返回為unicode亂碼的解決方法
本文給大家分享了新版Flask實現(xiàn)的接口響應(yīng)中存在中文時接口返回為unicode亂碼的解決方法,文中通過代碼示例和圖文介紹的非常詳細,如果有遇到相同問題的朋友,可以參考閱讀本文2023-11-11詳解Python如何實現(xiàn)Excel數(shù)據(jù)讀取和寫入
這篇文章主要為大家詳細介紹了python如何實現(xiàn)對EXCEL數(shù)據(jù)進行讀取和寫入,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-04-04JupyterNotebook 如何調(diào)整輸出窗口的顯示效果
這篇文章主要介紹了JupyterNotebook 輸出窗口的顯示效果調(diào)整實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-09-09