Python自動化之定位方法大殺器xpath
一、xpath:基本屬性定位
上一篇文章講了通過元素的id、name、class這些屬性定位的用戶,使用xpath方法結合元素屬性也可以很準確的定位元素,如下圖
于是可以用以下xpath方法定位
二、xpath:其他屬性定位
在實際工作過程中,往往會遇到一個元素id、name、class屬性都沒有,這時候也可以通過其它屬性定位到
三、xpath:標簽定位
在實際工作中,還會遇到一種情況就是相同屬性具有同一個名字,這時就需要通過標簽篩選,定位更準一點
如果不想制定標簽名稱,可以用*號表示任意標簽
如果想制定具體某個標簽,就可以直接寫標簽名稱
四、xpath:相對路徑/絕對路徑定位
1.如果一個元素,它的屬性不是很明顯,無法直接定位到,這時候我們可以先找它上一層元素(父元素)
2.找到父元素后,再找下個層級就能定位到了
3.如上圖所示,要定位的是input這個標簽,它的老爸的id=s_kw_wrap.
4.要是它老爸的屬性也不是很明顯,就找它爺爺id=form
5.于是就可以通過層級關系定位到
五、xpath:索引
1.如果一個元素它的兄弟元素跟它的標簽一樣,這時候無法通過層級定位到。因為都是一個父親生的,多胞胎兄弟。
2.雖然雙胞胎兄弟很難識別,但是出生是有先后的,于是可以通過它在家里的排行老幾定位到。
3.如下圖三胞胎兄弟
4.用xpath定位老大、老二和老三(這里索引是從1開始算起的,跟Python的索引不一樣)
六、xpath:邏輯運算
1.xpath還有一個比較強的功能,是可以多個屬性邏輯運算的,可以支持與(and)、或(or)、非(not)
2.一般用的比較多的是and運算,同時滿足兩個屬性
七、xpath:模糊匹配
1.xpath還有一個非常強大的功能,模糊匹配
2.掌握了模糊匹配功能,基本上沒有定位不到的
3.比如我要定位百度頁面的超鏈接“hao123”,在上一篇中講過可以通過by_link,也可以通過by_partial_link,模糊匹配定位到。當然xpath也可以有同樣的功能,并且更為強大。
可以把xpath看成是元素定位界的屠龍刀。
到此這篇關于Python自動化之定位方法大殺器xpath的文章就介紹到這了,更多相關Python xpath內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
python使用pandas讀取json文件并進行刷選導出xlsx文件的方法示例
這篇文章主要介紹了python使用pandas讀取json文件并進行刷選導出xlsx文件的方法,結合實例形式分析了python調用pandas模塊針對json數(shù)據(jù)操作的相關使用技巧,需要的朋友可以參考下2023-06-06Python3 Tkinter選擇路徑功能的實現(xiàn)方法
今天小編就為大家分享一篇Python3 Tkinter選擇路徑功能的實現(xiàn)方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-06-06Python深度學習pytorch神經(jīng)網(wǎng)絡塊的網(wǎng)絡之VGG
雖然AlexNet證明深層神經(jīng)網(wǎng)絡卓有成效,但它沒有提供一個通用的模板來指導后續(xù)的研究人員設計新的網(wǎng)絡。下面,我們將介紹一些常用于設計深層神經(jīng)網(wǎng)絡的啟發(fā)式概念2021-10-10python?中的?BeautifulSoup?網(wǎng)頁使用方法解析
這篇文章主要介紹了python?中的?BeautifulSoup?網(wǎng)頁使用方法解析,文章基于python的相關資料展開詳細內容介紹,具有一定的參考價值需要的小伙伴可以參考一下2022-04-04Python+OpenCV實現(xiàn)分水嶺分割算法的示例代碼
分水嶺算法是用于分割的經(jīng)典算法,在提取圖像中粘連或重疊的對象時特別有用。本文將用Python+OpenCV實現(xiàn)這一算法,需要的可以參考一下2022-08-08