使用CSS選擇器進行元素定位


         在selenium webdriver中,支持使用CSS選擇器來進行元素定位,事實在真的投入工作,大量編輯用例和元素定位的時候,使用css 和 xpath才是經常需要用到的。
之前有專門講過使用xpath對元素定位的使用,下面要介紹css選擇器來進行元素定位。

【參見W3C官網說明】

先看看css選擇器定位的webdriver函數:
   
   
   
           
  1. def find_elements_by_css_selector(self, css_selector):
  2. """
  3. Finds elements by css selector.
  4. :Args:
  5. - css_selector: The css selector to use when finding elements.
  6. :Usage:
  7. driver.find_elements_by_css_selector('.foo')
  8. """
  9. return self.find_elements(by=By.CSS_SELECTOR, value=css_selector)

常見語法

CSS選擇器用於選擇你想要的元素的樣式的模式。

"CSS"列表示在CSS版本的屬性定義(CSS1,CSS2,或對CSS3)。

選擇器 示例 示例說明 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] 選擇標題屬性包含單詞"flower"的所有元素 2
[attribute|=language] [lang|=en] 選擇一個lang屬性的起始值="EN"的所有元素 2
element1~element2 p~ul 選擇p元素之后同級的每一個ul元素 3
[attribute^=value] a[src^="https"] 選擇每一個src屬性的值以"https"開頭的元素 3
[attribute$=value] a[src$=".pdf"] 選擇每一個src屬性的值以".pdf"結尾的元素 3
[attribute*=value] a[src*="44lan"] 選擇每一個src屬性的值包含子字符串"44lan"的元素 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) 選擇每個p元素的是其父級的第二個子元素,從最后一個子項計數 3
:nth-of-type(n) p:nth-of-type(2) 選擇每個p元素是其父級的第二個p元素 3
:nth-last-of-type(n) p:nth-last-of-type(2) 選擇每個p元素的是其父級的第二個p元素,從最后一個子項計數 3
:last-child p:last-child 選擇每個p元素是其父級的最后一個子級。 3
:root :root 選擇文檔的根元素 3
:empty p:empty 選擇每個沒有任何子級的p元素(包括文本節點) 3
:target #news:target 選擇當前活動的#news元素(包含該錨名稱的點擊的URL) 3
:enabled input:enabled 選擇每一個已啟用的輸入元素 3
:disabled input:disabled 選擇每一個禁用的輸入元素 3
:checked input:checked 選擇每個選中的輸入元素 3
:not(selector) :not(p) 選擇每個並非p元素的元素 3
::selection ::selection 匹配元素中被用戶選中或處於高亮狀態的部分 3
:out-of-range :out-of-range 匹配值在指定區間之外的input元素 3
:in-range :in-range 匹配值在指定區間之內的input元素 3
:read-write :read-write 用於匹配可讀及可寫的元素 3
:read-only :read-only 用於匹配設置 "readonly"(只讀) 屬性的元素 3
:optional :optional 用於匹配可選的輸入元素 3
:required :required 用於匹配設置了 "required" 屬性的元素 3
:valid :valid 用於匹配輸入值為合法的元素 3
:invalid :invalid 用於匹配輸入值為非法的元素 3


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM