xpath是一種用來在xml文件中定位標(biāo)簽的一種語言。小編第一次認(rèn)識(shí)到這種語言是在selenium定位的時(shí)候。selenium定位中有一種定位器是幾乎萬能的,那就是xpath定位器。接下來這篇文章,我們就來介紹一下這個(gè)萬能的定位器xpath怎么用吧!
一、xpath:基本屬性定位
上一篇文章講了通過元素的id、name、class這些屬性定位的用戶,使用xpath方法結(jié)合元素屬性也可以很準(zhǔn)確的定位元素,如下圖
于是可以用以下xpath方法定位
二、xpath:其他屬性定位
在實(shí)際工作過程中,往往會(huì)遇到一個(gè)元素id、name、class屬性都沒有,這時(shí)候也可以通過其它屬性定位到
三、xpath:標(biāo)簽定位
在實(shí)際工作中,還會(huì)遇到一種情況就是相同屬性具有同一個(gè)名字,這時(shí)就需要通過標(biāo)簽篩選,定位更準(zhǔn)一點(diǎn)
如果不想制定標(biāo)簽名稱,可以用*號(hào)表示任意標(biāo)簽
如果想制定具體某個(gè)標(biāo)簽,就可以直接寫標(biāo)簽名稱
四、xpath:相對(duì)路徑/絕對(duì)路徑定位
1.如果一個(gè)元素,它的屬性不是很明顯,無法直接定位到,這時(shí)候我們可以先找它上一層元素(父元素)
2.找到父元素后,再找下個(gè)層級(jí)就能定位到了
3.如上圖所示,要定位的是input這個(gè)標(biāo)簽,它的老爸的id=s_kw_wrap.
4.要是它老爸的屬性也不是很明顯,就找它爺爺id=form
5.于是就可以通過層級(jí)關(guān)系定位到
五、xpath:索引
1.如果一個(gè)元素它的兄弟元素跟它的標(biāo)簽一樣,這時(shí)候無法通過層級(jí)定位到。因?yàn)槎际且粋€(gè)父親生的,多胞胎兄弟。
2.雖然雙胞胎兄弟很難識(shí)別,但是出生是有先后的,于是可以通過它在家里的排行老幾定位到。
3.如下圖三胞胎兄弟
4.用xpath定位老大、老二和老三(這里索引是從1開始算起的,跟Python的索引不一樣)
六、xpath:邏輯運(yùn)算
1.xpath還有一個(gè)比較強(qiáng)的功能,是可以多個(gè)屬性邏輯運(yùn)算的,可以支持與(and)、或(or)、非(not)
2.一般用的比較多的是and運(yùn)算,同時(shí)滿足兩個(gè)屬性
七、xpath:模糊匹配
1.xpath還有一個(gè)非常強(qiáng)大的功能,模糊匹配
2.掌握了模糊匹配功能,基本上沒有定位不到的
3.比如我要定位百度頁面的超鏈接“hao123”,在上一篇中講過可以通過by_link,也可以通過by_partial_link,模糊匹配定位到。當(dāng)然xpath也可以有同樣的功能,并且更為強(qiáng)大。
可以把xpath看成是元素定位界的屠龍刀。
到此這篇關(guān)于xpath怎么用的文章就介紹到這了,更多python知識(shí)和xpath知識(shí)可以關(guān)注W3Cschool以前的文章或繼續(xù)瀏覽下面的相關(guān)文章!