selenium學(xué)習(xí)教程之定位以及切換frame(iframe)
總有人看不明白,以防萬一,先在開頭大寫加粗說明一下:
frameset不用切,frame需層層切!
很多人在用selenium定位頁面元素的時候會遇到定位不到的問題,明明元素就在那兒,用firebug也可以看到,就是定位不到,這種情況很有可能是frame在搞鬼(原因之一,改天專門說說定位不到元素,可能的一些原因及處理辦法)。
frame標(biāo)簽有frameset、frame、iframe三種,frameset跟其他普通標(biāo)簽沒有區(qū)別,不會影響到正常的定位,而frame與iframe對selenium定位而言是一樣的,selenium有一組方法對frame進(jìn)行操作。
1.怎么切到frame中(switch_to.frame())
selenium提供了switch_to.frame()方法來切換frame
switch_to.frame(reference)
不得不提到switch_to_frame(),很多人在這樣寫的時候會發(fā)現(xiàn),這句話被劃上了刪除線,原因是這個方法已經(jīng)out了,之后很有可能會不支持,建議的寫法是switch_to.frame()
reference是傳入的參數(shù),用來定位frame,可以傳入id、name、index以及selenium的WebElement對象,假設(shè)有如下HTML代碼 index.html:
<html lang="en"> <head> <title>FrameTest</title> </head> <body> <iframe src="a.html" id="frame1" name="myframe"></iframe> </body> </html>
想要定位其中的iframe并切進(jìn)去,可以通過如下代碼:
from selenium import webdriver
driver = webdriver.Firefox()
driver.switch_to.frame(0) # 1.用frame的index來定位,第一個是0
# driver.switch_to.frame("frame1") # 2.用id來定位
# driver.switch_to.frame("myframe") # 3.用name來定位
# driver.switch_to.frame(driver.find_element_by_tag_name("iframe")) # 4.用WebElement對象來定位
通常采用id和name就能夠解決絕大多數(shù)問題。但有時候frame并無這兩項屬性,則可以用index和WebElement來定位:
- index從0開始,傳入整型參數(shù)即判定為用index定位,傳入str參數(shù)則判定為用id/name定位
- WebElement對象,即用find_element系列方法所取得的對象,我們可以用tag_name、xpath等來定位frame對象
舉個栗子:
<iframe src="myframetest.html" />
用xpath定位,傳入WebElement對象:
driver.switch_to.frame(driver.find_element_by_xpath("http://iframe[contains(@src,'myframe')]"))
2.從frame中切回主文檔(switch_to.default_content())
切到frame中之后,我們便不能繼續(xù)操作主文檔的元素,這時如果想操作主文檔內(nèi)容,則需切回主文檔。
driver.switch_to.default_content()
3.嵌套frame的操作(switch_to.parent_frame())
有時候我們會遇到嵌套的frame,如下:
<html> <iframe id="frame1"> <iframe id="frame2" / > </iframe> </html>
1.從主文檔切到frame2,一層層切進(jìn)去
driver.switch_to.frame("frame1")
driver.switch_to.frame("frame2")
2.從frame2再切回frame1,這里selenium給我們提供了一個方法能夠從子frame切回到父frame,而不用我們切回主文檔再切進(jìn)來。
driver.switch_to.parent_frame() # 如果當(dāng)前已是主文檔,則無效果
有了parent_frame()這個相當(dāng)于后退的方法,我們可以隨意切換不同的frame,隨意的跳來跳去了。
所以只要善用以下三個方法,遇到frame分分鐘搞定:
driver.switch_to.frame(reference) driver.switch_to.parent_frame() driver.switch_to.default_content()
補(bǔ)充
另外補(bǔ)充一下,之前曾看到過用點(diǎn)分法來切入嵌套frame的方法,但我試驗之后發(fā)現(xiàn)并不能定位到frame,如果有同學(xué)可以成功,麻煩留言告知一下,用法如下:
driver.switch_to.frame('frame1.0.frame3')
據(jù)說以上代碼可以切到 “frame1” 下的 “第一個frame” 下的 “frame3” 中。
總結(jié)
到此這篇關(guān)于selenium學(xué)習(xí)教程之定位以及切換frame(iframe)的文章就介紹到這了,更多相關(guān)selenium定位及切換frame(iframe)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
使用python框架Scrapy爬取數(shù)據(jù)的操作步驟
Scrapy是一個基于Python的強(qiáng)大的開源網(wǎng)絡(luò)爬蟲框架,用于從網(wǎng)站上抓取信息,它提供了廣泛的功能,使得爬取和分析數(shù)據(jù)變得相對容易,本文小編將給給大家介紹一下如何使用python框架Scrapy爬取數(shù)據(jù),需要的朋友可以參考下2023-10-10
Python 實現(xiàn)使用dict 創(chuàng)建二維數(shù)據(jù)、DataFrame
下面小編就為大家分享一篇Python 實現(xiàn)使用dict 創(chuàng)建二維數(shù)據(jù)、DataFrame,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-04-04
django數(shù)據(jù)庫遷移migration實現(xiàn)
這篇文章主要介紹了django數(shù)據(jù)庫遷移migration實現(xiàn),遷移任務(wù)是根據(jù)對models.py文件的改動情況,添加或者刪除表和列,下面詳細(xì)的相關(guān)內(nèi)容需要的小伙伴可以參考一下2022-02-02
Python辦公自動化之網(wǎng)絡(luò)監(jiān)控和壓縮文件處理
Python辦公?動化是利用Python編程語?來創(chuàng)建腳本和程序,以簡化、加速和?動化?常辦公任務(wù)和工作流程的過程,本文主要介紹了如何進(jìn)行網(wǎng)絡(luò)監(jiān)控和壓縮文件處理,感興趣的可以了解下2023-12-12
用Python實現(xiàn)服務(wù)器中只重載被修改的進(jìn)程的方法
這篇文章主要介紹了用Python實現(xiàn)服務(wù)器中只重載被修改的進(jìn)程的方法,包括用watchdog來檢測文件的變化等,實現(xiàn)起來充分體現(xiàn)了Python作為動態(tài)語言的靈活性,強(qiáng)烈推薦!需要的朋友可以參考下2015-04-04

