Python selenium 父子、兄弟、相鄰節(jié)點(diǎn)定位方式詳解
今天跟大家分享下selenium中根據(jù)父子、兄弟、相鄰節(jié)點(diǎn)定位的方法,很多人在實(shí)際應(yīng)用中會(huì)遇到想定位的節(jié)點(diǎn)無(wú)法直接定位,需要通過(guò)附近節(jié)點(diǎn)來(lái)相對(duì)定位的問題,但從父節(jié)點(diǎn)定位子節(jié)點(diǎn)容易,從子節(jié)點(diǎn)定位父節(jié)點(diǎn)、定位一個(gè)節(jié)點(diǎn)的哥哥節(jié)點(diǎn)就一籌莫展了,別急,且看博主一步步講解。
1. 由父節(jié)點(diǎn)定位子節(jié)點(diǎn)
最簡(jiǎn)單的肯定就是由父節(jié)點(diǎn)定位子節(jié)點(diǎn)了,我們有很多方法可以定位,下面上個(gè)例子:
對(duì)以下代碼:
<html> <body> <div id="A"> <!--父節(jié)點(diǎn)定位子節(jié)點(diǎn)--> <div id="B"> <div>parent to child</div> </div> </div> </body> </html>
想要根據(jù) B節(jié)點(diǎn) 定位無(wú)id的子節(jié)點(diǎn),代碼示例如下:
# -*- coding: utf-8 -*- from selenium import webdriver driver = webdriver.Firefox() driver.get('D:\\py\\AutoTestFramework\\src\\others\\test.html') # 1.串聯(lián)尋找 print driver.find_element_by_id('B').find_element_by_tag_name('div').text # 2.xpath父子關(guān)系尋找 print driver.find_element_by_xpath("http://div[@id='B']/div").text # 3.css selector父子關(guān)系尋找 print driver.find_element_by_css_selector('div#B>div').text # 4.css selector nth-child print driver.find_element_by_css_selector('div#B div:nth-child(1)').text # 5.css selector nth-of-type print driver.find_element_by_css_selector('div#B div:nth-of-type(1)').text # 6.xpath軸 child print driver.find_element_by_xpath("http://div[@id='B']/child::div").text driver.quit()
結(jié)果:
parent to child
parent to child
parent to child
parent to child
parent to child
parent to child
第1到第3都是我們熟悉的方法,便不再多言。第4種方法用到了css選擇器:nth-child(n),該選擇器返回第n個(gè)節(jié)點(diǎn),該節(jié)點(diǎn)為div標(biāo)簽;第5種方法用到了另一個(gè)css選擇器: nth-of-type(n),該選擇器返回第n個(gè)div標(biāo)簽,注意與上一個(gè)選擇器的區(qū)別;第6種方法用到了xpath軸 child,這個(gè)是xpath默認(rèn)的軸,可以忽略不寫,其實(shí)質(zhì)是跟方法2一樣的。
當(dāng)然,css中還有一些選擇器是可以選擇父子關(guān)系的如last-child、nth-last-child等,感興趣可以自行百度,有機(jī)會(huì)博主會(huì)講講css selector。
2. 由子節(jié)點(diǎn)定位父節(jié)點(diǎn)
由子節(jié)點(diǎn)想要定位到父節(jié)點(diǎn)就有點(diǎn)難度了,對(duì)以下代碼:
<html> <body> <div id="A"> <!--子節(jié)點(diǎn)定位父節(jié)點(diǎn)--> <div> <div>child to parent <div> <div id="C"></div> </div> </div> </div> </div> </body> </html>
我們想要由 C節(jié)點(diǎn) 定位其兩層父節(jié)點(diǎn)的div,示例代碼如下:
# -*- coding: utf-8 -*- from selenium import webdriver driver = webdriver.Firefox() driver.get('D:\\py\\AutoTestFramework\\src\\others\\test.html') # 1.xpath: `.`代表當(dāng)前節(jié)點(diǎn); '..'代表父節(jié)點(diǎn) print driver.find_element_by_xpath("http://div[@id='C']/../..").text # 2.xpath軸 parent print driver.find_element_by_xpath("http://div[@id='C']/parent::*/parent::div").text driver.quit()
結(jié)果:
child to parent
child to parent
這里我們有兩種辦法,第1種是 .. 的形式,就像我們知道的,. 表示當(dāng)前節(jié)點(diǎn),.. 表示父節(jié)點(diǎn);第2種辦法跟上面一樣,是xpath軸中的一個(gè):parent,取當(dāng)前節(jié)點(diǎn)的父節(jié)點(diǎn)。這里也是css selector的一個(gè)痛點(diǎn),因?yàn)閏ss的設(shè)計(jì)不允許有能夠獲取父節(jié)點(diǎn)的辦法(至少目前沒有)
3. 由弟弟節(jié)點(diǎn)定位哥哥節(jié)點(diǎn)
這是第3、第4種情況,我們這里要定位的是兄弟節(jié)點(diǎn)了。如以下源碼:
<html> <body> <div id="A"> <!--下面兩個(gè)節(jié)點(diǎn)用于兄弟節(jié)點(diǎn)定位--> <div>brother 1</div> <div id="D"></div> <div>brother 2</div> </div> </body> </html>
怎么通過(guò) D節(jié)點(diǎn) 定位其哥哥節(jié)點(diǎn)呢?看代碼示例:
# -*- coding: utf-8 -*- from selenium import webdriver driver = webdriver.Firefox() driver.get('D:\\Code\\py\\AutoTestFramework\\src\\others\\test.html') # 1.xpath,通過(guò)父節(jié)點(diǎn)獲取其哥哥節(jié)點(diǎn) print driver.find_element_by_xpath("http://div[@id='D']/../div[1]").text # 2.xpath軸 preceding-sibling print driver.find_element_by_xpath("http://div[@id='D']/preceding-sibling::div[1]").text driver.quit()
結(jié)果
brother 1
brother 1
這里博主也列舉了兩種方法,一種是通過(guò)該節(jié)點(diǎn)的父節(jié)點(diǎn)來(lái)獲得哥哥節(jié)點(diǎn),另外一種比較優(yōu)雅,是通過(guò) xpath軸:preceding-sibling,其能夠獲取當(dāng)前節(jié)點(diǎn)的所有同級(jí)哥哥節(jié)點(diǎn),注意括號(hào)里的標(biāo)號(hào),1 代表著離當(dāng)前節(jié)點(diǎn)最近的一個(gè)哥哥節(jié)點(diǎn),數(shù)字越大表示離當(dāng)前節(jié)點(diǎn)越遠(yuǎn),當(dāng)然,xpath軸:preceding也可以,但是使用起來(lái)比較復(fù)雜,它獲取到的是該節(jié)點(diǎn)之前的所有非祖先節(jié)點(diǎn)(這里不太好解釋,改天專門寫篇博文講解下所有的軸)
4. 由哥哥節(jié)點(diǎn)定位弟弟節(jié)點(diǎn)
源碼與 3 一致,要想通過(guò) D節(jié)點(diǎn) 定位其弟弟節(jié)點(diǎn),看代碼示例:
# -*- coding: utf-8 -*- from selenium import webdriver driver = webdriver.Firefox() driver.get('D:\\Code\\py\\AutoTestFramework\\src\\others\\test.html') # 1.xpath,通過(guò)父節(jié)點(diǎn)獲取其弟弟節(jié)點(diǎn) print driver.find_element_by_xpath("http://div[@id='D']/../div[3]").text # 2.xpath軸 following-sibling print driver.find_element_by_xpath("http://div[@id='D']/following-sibling::div[1]").text # 3.xpath軸 following print driver.find_element_by_xpath("http://div[@id='D']/following::*").text # 4.css selector + print driver.find_element_by_css_selector('div#D + div').text # 5.css selector ~ print driver.find_element_by_css_selector('div#D ~ div').text driver.quit()
結(jié)果:
brother 2
brother 2
brother 2
brother 2
brother 2
博主分享了五種方法定位其弟弟節(jié)點(diǎn),上面三種是用xpath,第一種很好理解,第二種用到了xpath軸:following-sibling,跟preceding-sibling類似,它的作用是獲取當(dāng)前節(jié)點(diǎn)的所有同級(jí)弟弟節(jié)點(diǎn),同樣,1 代表離當(dāng)前節(jié)點(diǎn)最近的一個(gè)弟弟節(jié)點(diǎn),數(shù)字越大表示離當(dāng)前節(jié)點(diǎn)越遠(yuǎn);第三種用到了xpath軸:following,獲取到該節(jié)點(diǎn)之后所有節(jié)點(diǎn),除了祖先節(jié)點(diǎn)(跟preceding方向相反,但因?yàn)橥马樞蛉菀鬃x,不容易出錯(cuò),所以也是可以用來(lái)獲取弟弟節(jié)點(diǎn)的,但也不建議這么使用);第四、第五種,我們用到了css selector,+ 和 ~ 的區(qū)別是: + 表示緊跟在當(dāng)前節(jié)點(diǎn)之后的div節(jié)點(diǎn),~ 表示當(dāng)前節(jié)點(diǎn)之后的div節(jié)點(diǎn),如果用find_elements,則可獲取到一組div節(jié)點(diǎn)。
以上所述是小編給大家介紹的Python selenium 父子、兄弟、相鄰節(jié)點(diǎn)定位方式詳解的全部敘述,希望對(duì)大家有所幫助,如果大家有任何疑問歡迎給我留言,小編會(huì)及時(shí)回復(fù)大家的,在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
- Python實(shí)現(xiàn)針對(duì)給定單鏈表刪除指定節(jié)點(diǎn)的方法
- Python基于lxml模塊解析html獲取頁(yè)面內(nèi)所有葉子節(jié)點(diǎn)xpath路徑功能示例
- python 通過(guò)xml獲取測(cè)試節(jié)點(diǎn)和屬性的實(shí)例
- python+matplotlib繪制簡(jiǎn)單的海豚(頂點(diǎn)和節(jié)點(diǎn)的操作)
- Python算法之求n個(gè)節(jié)點(diǎn)不同二叉樹個(gè)數(shù)
- python xml.etree.ElementTree遍歷xml所有節(jié)點(diǎn)實(shí)例詳解
- Python獲取任意xml節(jié)點(diǎn)值的方法
- python實(shí)現(xiàn)單鏈表中刪除倒數(shù)第K個(gè)節(jié)點(diǎn)的方法
相關(guān)文章
Python:__eq__和__str__函數(shù)的使用示例
這篇文章主要介紹了Python:__eq__和__str__函數(shù)的使用示例,幫助大家更好的理解和學(xué)習(xí)python,感興趣的朋友可以了解下2020-09-09Pyside2中嵌入Matplotlib的繪圖的實(shí)現(xiàn)
這篇文章主要介紹了Pyside2中嵌入Matplotlib的繪圖的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2021-02-02Pandas中DataFrame數(shù)據(jù)刪除詳情
這篇文章主要以介紹的是Pandas中DataFrame的數(shù)據(jù)刪除的相關(guān)資料,主要使用drop、del方式,需要的朋友可以參考下面文章的具體內(nèi)容2021-09-09使用Python Tkinter實(shí)現(xiàn)剪刀石頭布小游戲功能
這篇文章主要介紹了使用Python Tkinter實(shí)現(xiàn)剪刀石頭布小游戲功能,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-10-10python中獲得當(dāng)前目錄和上級(jí)目錄的實(shí)現(xiàn)方法
這篇文章主要介紹了python中獲得當(dāng)前目錄和上級(jí)目錄的實(shí)現(xiàn)方法,需要的朋友可以參考下2017-10-10python利用logging模塊實(shí)現(xiàn)根據(jù)日志級(jí)別打印不同顏色日志的代碼案例
這篇文章主要介紹了python利用logging模塊實(shí)現(xiàn)根據(jù)日志級(jí)別打印不同顏色日志,本文通過(guò)實(shí)例代碼給大家詳細(xì)講解,對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-12-12