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 |