Selenium元素定位方法大彙總,及XPath、CSS定位詳解

Selenium元素定位方法大彙總,及XPath、CSS定位詳解

1.所有方法彙總

方式 示例 說明
identifier Click Element | identifier=my_element 匹配 id 或 name 屬性
id Click Element | id=my_element 匹配 id 屬性
name Click Element | name=my_element 匹配 name 屬性
xpath Click Element | xpath=//div[@id=‘my_element’] 匹配 Xpath 表達式
dom Click Element | dom=document.images[56] 匹配DOM表達式
link Click Element | link=My Link 匹配錨點的鏈接文字
partial link Click Element | partial link=y Lin 匹配錨點的部分鏈接文字
css Click Element | css=div.my_class 匹配 CSS
jquery Click Element | jquery=div.my_class 匹配jQuery/sizzle選擇器
sizzle Click Element | sizzle=div.my_class 匹配jQuery/sizzle選擇器
tag Click Element | tag=div 匹配元素的HTML tag 名稱
default* Click Link | default=page?a=b 匹配第一個=後面的關鍵屬性

2.XPath定位詳解

XPath運算符 說明
/ 此路徑運算符出現在模式開頭時,表示應從根節點選擇。
// 從當前節點開始遞歸下降,此路徑運算符出現在模式開頭時,表示應從根節點遞歸下降。
. 當前上下文。
當前上下文節點父級。
* 通配符;選擇所有元素節點與元素名無關。(不包括文本,註釋,指令等節點,如果也要包含這些節點請用node()函數)
@ 屬性名的前綴。
@* 選擇所有屬性,與名稱無關。
: 命名空間分隔符;將命名空間前綴與元素名或屬性名分隔。
( ) 括號運算符(優先級最高),強制運算優先級。
[ ] 應用篩選模式(即謂詞,包括"過濾表達式"和"軸(向前/向後)")。
[ ] 下標運算符;用於在集合中編制索引。
| 兩個節點集合的聯合,如://messages/message/to | //messages/message/cc
- 減法。
div 浮點除法。
and, or 邏輯運算。
mod 求餘。
not() 邏輯非
= 等於
!= 不等於
特殊比較運算符 < 或者 <= 或者 > 或者 >=
XPath軸名稱 說明
ancestor 選取當前節點的所有先輩(父、祖父等)
ancestor-or-self 選取當前節點的所有先輩(父、祖父等)以及當前節點本身
attribute 選取當前節點的所有屬性
child 選取當前節點的所有子元素。
descendant 選取當前節點的所有後代元素(子、孫等)。
descendant-or-self 選取當前節點的所有後代元素(子、孫等)以及當前節點本身。
following 選取文檔中當前節點的結束標籤之後的所有節點。
namespace 選取當前節點的所有命名空間節點
parent 選取當前節點的父節點。
preceding 直到所有這個節點的父輩節點,順序選擇每個父輩節點前的所有同級節點
preceding-sibling 選取當前節點之前的所有同級節點。
self 選取當前節點。
常用表達式舉例 說明
/ Document Root文檔根.
/* 選擇文檔根下面的所有元素節點,即根節點(XML文檔只有一個根節點)
/node() 根元素下所有的節點(包括文本節點,註釋節點等)
/text() 查找文檔根節點下的所有文本節點
/messages/message messages節點下的所有message節點
/messages/message[1] messages節點下的第一個message節點
/messages/message[1]/self::node() 第一個message節點(self軸表示自身,node()表示選擇所有節點)
/messages/message[1]/node() 第一個message節點下的所有子節點
/messages/message[1]/*[last()] 第一個message節點的最後一個子節點
/messages/message[1]/[last()] Error,謂詞前必須是節點或節點集
/messages/message[1]/node()[last()] 第一個message節點的最後一個子節點
/messages/message[1]/text() 第一個message節點的所有子節點
/messages/message[1]//text() 第一個message節點下遞歸下降查找所有的文本節點(無限深度)
/messages/message[1] /child::node() 第一個message節點下的所有子節點
/messages/message[1] /node() 第一個message節點下的所有子節點
/messages/message[position()=1]/node() 第一個message節點下的所有子節點
//message[@id=1] /node() 第一個message節點下的所有子節點
//message[@id=1] //child::node() 遞歸所有子節點(無限深度)
//message[position()=1]/node() 選擇id=1的message節點以及id=0的message節點
/messages/message[1] /parent:: * Messages節點
/messages/message[1]/body/attachments/parent::node() attachments節點的父節點。父節點只有一個,所以node()和* 返回結果一樣。
/messages/message[1]/body/attachments/parent:: * attachments節點的父節點。父節點只有一個,所以node()和* 返回結果一樣。
/messages/message[1]/body/attachments/. . attachments節點的父節點。
//message[@id=0]/ancestor:: * Ancestor軸表示所有的祖輩,父,祖父等。 向上遞歸
//message[@id=0]/ancestor-or-self:: * 向上遞歸,包含自身
//message[@id=0]/ancestor::node() 對比使用*,多一個文檔根元素(Document root)
/messages/message[1]/descendant::node() 遞歸下降查找message節點的所有節點
//messages/message[1]//node() 遞歸下降查找message節點的所有節點
/messages/message[1]/sender/following:: * 查找第一個message節點的sender節點後的所有同級節點,並對每一個同級節點遞歸向下查找。
//message[@id=1]/sender/following-sibling:: * 查找id=1的message節點的sender節點的所有後續的同級節點。
//message[@id=1]/datetime/@date 查找id=1的message節點的datetime節點的date屬性
//message[@id=1]/datetime[@date] 查找id=1的message節點的所有含有date屬性的datetime節點
//message/datetime[attribute::date] 查找message節點的所有含有date屬性的datetime節點
//message[datetime] 查找所有含有datetime節點的message節點
//message/datetime/attribute:: * 返回message節點下datetime節點的所有屬性節點
//message/datetime/attribute::node() 返回message節點下datetime節點的所有屬性節點
//message/datetime/@* 返回message節點下datetime節點的所有屬性節點
//message/datetime[attribute:: *] 選擇所有含有屬性的datetime節點
//message/datetime[attribute::node()] 選擇所有含有屬性的datetime節點
//message/datetime[@*] 選擇所有含有屬性的datetime節點
//message/datetime[@node()] 選擇所有含有屬性的datetime節點
//attribute:: * 選擇根節點下的所有屬性節點
//message[@id=0]/body/preceding::node() 順序選擇body節點所在節點前的所有同級節點。(查找順序爲:先找到body節點的頂級節點(根節點),得到根節點標籤前的所有同級節點,執行完成後繼續向下一級,順序得到該節點標籤前的所有同級節點,依次類推。) 注意:查找同級節點是順序查找,而不是遞歸查找。
//message[@id=0]/body/preceding-sibling::node() 順序查找body標籤前的所有同級節點。(和上例一個最大的區別是:不從最頂層開始到body節點逐層查找。我們可以理解成少了一個循環,而只查找當前節點前的同級節點)
//message[@id=1]//*[namespace::amazon] 查找id=1的所有message節點下的所有命名空間爲amazon的節點。
//namespace:: * 文檔中的所有的命名空間節點。(包括默認命名空間xmlns:xml)
//message[@id=0]//books/*[local-name()=‘book’] 選擇books下的所有的book節點, 注意:由於book節點定義了命名空間amazone:book.若寫成//message[@id=0]//books/book則查找不出任何節點。
//message[@id=0]//books/*[local-name()=‘book’ and namespace-uri()=‘http://www.amazon.com/books/schema’] 選擇books下的所有的book節點,(節點名和命名空間都匹配)
//message[@id=0]//books/*[local-name()=‘book’][year>2006] 選擇year節點值>2006的book節點
//message[@id=0]//books/*[local-name()=‘book’][1]/year>2006 指示第一個book節點的year節點值是否大於2006. 返回xs:boolean: true

3.CSS定位詳解

CSS選擇器 示例 說明 CSS
.class .intro 選擇 class=“intro” 的所有元素。 1
#id #firstname 選擇 id=“firstname” 的所有元素。 1
* * 選擇所有元素。 2
element p 選擇所有 <p> 元素。 1
element,element div,p 選擇所有 <div> 元素和所有 <p> 元素。 1
element element div p 選擇 <div> 元素內部的所有 <p> 元素。 1
element>element div>p 選擇父元素爲 <div> 元素的所有 <p> 元素。 2
element+element div+p 選擇緊接在 <div> 元素之後的所有 <p> 元素。 2
[attribute] [target] 選擇帶有 target 屬性所有元素。 2
[attribute=value] [target=_blank] 選擇 target="_blank" 的所有元素。 2
[attribute~=value] [title~=flower] 選擇 title 屬性包含單詞 “flower” 的所有元素。 2
[attribute|=value] [lang|=en] 選擇 lang 屬性值以 “en” 開頭的所有元素。 2
:link a:link 選擇所有未被訪問的鏈接。 1
:visited a:visited 選擇所有已被訪問的鏈接。 1
:active a:active 選擇活動鏈接。 1
:hover a:hover 選擇鼠標指針位於其上的鏈接。 1
:focus input:focus 選擇獲得焦點的 input 元素。 2
:first-letter p:first-letter 選擇每個 <p> 元素的首字母。 1
:first-line p:first-line 選擇每個 <p> 元素的首行。 1
:first-child p:first-child 選擇屬於父元素的第一個子元素的每個 <p> 元素。 2
:before p:before 在每個 <p> 元素的內容之前插入內容。 2
:after p:after 在每個 <p> 元素的內容之後插入內容。 2
:lang(language) p:lang(it) 選擇帶有以 “it” 開頭的 lang 屬性值的每個 <p> 元素。 2
element1~element2 p~ul 選擇前面有 <p> 元素的每個 <ul> 元素。 3
[attribute^=value] a[src^=“https”] 選擇其 src 屬性值以 “https” 開頭的每個 <a> 元素。 3
[attribute$=value] a[src$=".pdf"] 選擇其 src 屬性以 “.pdf” 結尾的所有 <a> 元素。 3
[attribute*=value] a[src*=“abc”] 選擇其 src 屬性中包含 “abc” 子串的每個 <a> 元素。 3
:first-of-type p:first-of-type 選擇屬於其父元素的首個 <p> 元素的每個 <p> 元素。 3
:last-of-type p:last-of-type 選擇屬於其父元素的最後 <p> 元素的每個 <p> 元素。 3
:only-of-type p:only-of-type 選擇屬於其父元素唯一的 <p> 元素的每個 <p> 元素。 3
:only-child p:only-child 選擇屬於其父元素的唯一子元素的每個 <p> 元素。 3
:nth-child(n) p:nth-child(2) 選擇屬於其父元素的第二個子元素的每個 <p> 元素。 3
:nth-last-child(n) p:nth-last-child(2) 同上,從最後一個子元素開始計數。 3
:nth-of-type(n) p:nth-of-type(2) 選擇屬於其父元素第二個 <p> 元素的每個 <p> 元素。 3
:nth-last-of-type(n) p:nth-last-of-type(2) 同上,但是從最後一個子元素開始計數。 3
:last-child p:last-child 選擇屬於其父元素最後一個子元素每個 <p> 元素。 3
:root :root 選擇文檔的根元素。 3
:empty p:empty 選擇沒有子元素的每個 <p> 元素(包括文本節點)。 3
:target #news:target 選擇當前活動的 #news 元素。 3
:enabled input:enabled 選擇每個啓用的 <input> 元素。 3
:disabled input:disabled 選擇每個禁用的 <input> 元素。 3
:checked input:checked 選擇每個被選中的 <input> 元素。 3
:not(selector) :not§ 選擇非 <p> 元素的每個元素。 3
::selection ::selection 選擇被用戶選取的元素部分。 3
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章