xpath 定位方式

xpath的作用就是兩個字“定位”形葬,運用各種方法進行快速準確的定位外盯,推薦兩個非常有用的的firefox工具:firebug和xpath checker


定位

1.依靠自己屬性檀何,文本定位

//td[text()='xxx']

//div[contains(@class,'xxx')]

//div[@class='xxx' and @type='xxx']


2.依靠父節(jié)點定位

//div[@class='xxx']/div

//div[@id='xxx']/div



3.依靠子節(jié)點定位

//div[div[@id='xxx']]

//div[div[@name='xxx']]


4.混合型

//div[div[@name='xxx']]/img

//td[a/font[contains(text(),'xxx')]]//input[@type='xxx']


xpath的學習-拓展

1.following-sibling

following-sibling即為“選擇當前節(jié)點之后的所有同級節(jié)點”扔亥,那么沒有加上“sibling”關鍵字的挂签,搜索的就是之上/之下的所有節(jié)點,忽略同級概念凯力,例如:

? ?

要定位第二個input://input[@id='123']/following-sibling::input


2.preceding-sibling

preceding-sibling的解釋是“選取當前節(jié)點之前的所有同級節(jié)點”,那么沒有加上“sibling”關鍵字的礼华,搜索的就是之上/之下的所有節(jié)點咐鹤,忽略同級概念,? ???? ? ??? ? ? ? ? ? ?? ??preceding-sibling和following-sibling是剛好相反的

text

? ?

要定位第二個input://input[@id='123']/preceding-sibling::span


3.contains

和字面意思一樣就是包含圣絮,例如://div[contains(@class,'xxx')]


4.starts-with

和字面意思一樣就是以某某開頭祈惶,例如://input[starts-with(@class,'xxx')]


5.not

就是否定的意思

比如找一個id不為123的input:input[not[id='123']]

又如找一個文本中不包含xxx字段的span://span[not(contains(text(),'xxx'))]


xpath的學習-補充

絕對路徑html/body/div/span[2]/input[2] 中間結構變化,就失效

相對路徑//開始扮匠,在整個html source里找捧请,不管在什么位置


索引[x]//div/input[2] div下面第二個input


position()=2position()>3position()<3

例如html:

test position()1

test position()2

test position()3

test position()4

test position()5

獲取第一個span,可以是//div[@id='positions']/span[1]棒搜,也可以是//div[@id='positions']/span[position()=1]

//div[@id='positions']/span[position()>3]就是定位了test position()4和test position()5

//div[@id='positions']/span[position()<3]就是定位了test position()1和test position()2


last()last()-1

以上面的html為例子疹蛉,獲取最后一個span://div[@id='positions']/span[last()]

以上面的html為例子,獲取倒數(shù)第二個span://div[@id='positions']/span[last()-1]


屬性定位@class ? //div[@class] ?有class屬性的div

屬性值定位力麸,前面已經(jīng)講過了 ?//div[@class='xxx']


功能關鍵字

1.常用

and/[][]可款,比如://span[@name='xxx' and text()='xxx']也是可以寫成//span[@name='xxx'][text()='xxx']

or,比如以上面html為例子克蚂,定位文本為test position()5和test position()4的span://div[@id='positions']/span[text()='test position()5' or text()='test position()4']

not,contains,starts-with

ends-with 在xpath中是沒有這個的

2.不常用的

substring,substring-before,substing-after


sbustring(str,start-position,length)比如html:

text

定位上面html中span://div[@id='xxx']/span[substring(@name,3,5)='xxxxx']


substring-before的用法闺鲸,比如html

text

定位上面html中span://div[@id="xxx"]/span[sbustring-before(@class,"-")="spanclass1"]


substring-after的用法,比如html

text

定位上面html中span://div[@id="xxx"]/span[sbustring-after(@class,"-")="spanclass22"]

通配符 ?*

比如//span[@*="xxx"]指定位span中任意屬性包含xxx的

比如//*[@*="xxx"]指定位頁面中任意屬性保護xxx的標簽


Axes 軸

parent 父節(jié)點

ancestor 祖先節(jié)點埃叭,包括父節(jié)點摸恍,一層一層向上

descendant 所有子孫節(jié)點找,不管什么位置赤屋,簡寫//立镶,就是xpath中出現(xiàn)//的情況壁袄。。//div[@class="xxx"]//input

follwing-sibling 當前元素后面的兄弟姐妹

preceding-sibling 當前元素前面的兄弟姐妹

following 當前元素后面所有元素谜慌,一直到

preceding ?當前元素之前所有元素然想,一直到

ancestor-or-self

descendant-or-self

使用的時候注意加上::

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市欣范,隨后出現(xiàn)的幾起案子变泄,更是在濱河造成了極大的恐慌,老刑警劉巖恼琼,帶你破解...
    沈念sama閱讀 216,843評論 6 502
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件妨蛹,死亡現(xiàn)場離奇詭異,居然都是意外死亡晴竞,警方通過查閱死者的電腦和手機蛙卤,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,538評論 3 392
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來噩死,“玉大人颤难,你說我怎么就攤上這事∫盐” “怎么了行嗤?”我有些...
    開封第一講書人閱讀 163,187評論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長垛耳。 經(jīng)常有香客問我栅屏,道長,這世上最難降的妖魔是什么堂鲜? 我笑而不...
    開封第一講書人閱讀 58,264評論 1 292
  • 正文 為了忘掉前任栈雳,我火速辦了婚禮,結果婚禮上缔莲,老公的妹妹穿的比我還像新娘哥纫。我一直安慰自己,他們只是感情好痴奏,可當我...
    茶點故事閱讀 67,289評論 6 390
  • 文/花漫 我一把揭開白布磺箕。 她就那樣靜靜地躺著,像睡著了一般抛虫。 火紅的嫁衣襯著肌膚如雪松靡。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,231評論 1 299
  • 那天建椰,我揣著相機與錄音雕欺,去河邊找鬼。 笑死,一個胖子當著我的面吹牛屠列,可吹牛的內容都是我干的啦逆。 我是一名探鬼主播,決...
    沈念sama閱讀 40,116評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼笛洛,長吁一口氣:“原來是場噩夢啊……” “哼夏志!你這毒婦竟也來了?” 一聲冷哼從身側響起苛让,我...
    開封第一講書人閱讀 38,945評論 0 275
  • 序言:老撾萬榮一對情侶失蹤沟蔑,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后狱杰,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體瘦材,經(jīng)...
    沈念sama閱讀 45,367評論 1 313
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 37,581評論 2 333
  • 正文 我和宋清朗相戀三年仿畸,在試婚紗的時候發(fā)現(xiàn)自己被綠了食棕。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 39,754評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡错沽,死狀恐怖簿晓,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情千埃,我是刑警寧澤憔儿,帶...
    沈念sama閱讀 35,458評論 5 344
  • 正文 年R本政府宣布,位于F島的核電站镰禾,受9級特大地震影響,放射性物質發(fā)生泄漏唱逢。R本人自食惡果不足惜吴侦,卻給世界環(huán)境...
    茶點故事閱讀 41,068評論 3 327
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望坞古。 院中可真熱鬧备韧,春花似錦、人聲如沸痪枫。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,692評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽奶陈。三九已至易阳,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間吃粒,已是汗流浹背潦俺。 一陣腳步聲響...
    開封第一講書人閱讀 32,842評論 1 269
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人事示。 一個月前我還...
    沈念sama閱讀 47,797評論 2 369
  • 正文 我出身青樓早像,卻偏偏與公主長得像,于是被迫代替她去往敵國和親肖爵。 傳聞我的和親對象是個殘疾皇子卢鹦,可洞房花燭夜當晚...
    茶點故事閱讀 44,654評論 2 354

推薦閱讀更多精彩內容

  • Spring Cloud為開發(fā)人員提供了快速構建分布式系統(tǒng)中一些常見模式的工具(例如配置管理,服務發(fā)現(xiàn)劝堪,斷路器冀自,智...
    卡卡羅2017閱讀 134,652評論 18 139
  • 使用selenium進行自動化時少不了對元素進行定位,但目前前端大多使用框架vue幅聘,angular等凡纳,很多元素并沒...
    菠了個蘿閱讀 9,491評論 1 5
  • 每個人都不會花太多精力走進別人的世界,并試圖去理解帝蒿。 文│曦明 “所謂的旅游就是從自己呆膩的地方荐糜,去別人呆膩的地方...
    KSZxMX閱讀 622評論 0 8
  • 輕輕抬首,三亞的玲瓏清月葛超,沉溺在了骯臟的濃霧中暴氏,自歡。圣潔的光輝因此可惜的被黑暗隱晦了绣张。今夜答渔,我借來些廉價的酒,...
    在月下閱讀 358評論 1 5
  • 同學找我聊天侥涵,我說我在上課沼撕,沒時間。他說你都多大年紀了芜飘,還學瑜伽务豺,那么臭美干嘛? 我一驚嗦明,是傲ぁ!在很多男人的眼中...
    生之惑閱讀 2,005評論 24 29