selenium中CSS選擇器定位


selenium元素定位,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] 選擇標題屬性包含單詞"flower"的所有元素 2
[attribute|=language] [lang|=en] 選擇一個lang屬性的起始值="EN"的所有元素 2
:link a:link 選擇所有未訪問鏈接 1
:visited a:visited 選擇所有訪問過的鏈接 1
:active a:active 選擇活動鏈接 1
:hover a:hover 選擇鼠標在鏈接上面時 1
:focus input:focus 選擇具有焦點的輸入元素 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) 選擇一個lang屬性的起始值="it"的所有<p>元素 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*="runoob"] 選擇每一個src屬性的值包含子字符串"runoob"的元素 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
 
CSS定位selenium代碼示例如下
 1 #!/usr/bin/python
 2 # -*- coding: UTF-8 -*-
 3 from selenium import webdriver
 4 
 5 #取消提示
 6 option = webdriver.ChromeOptions()
 7 option.add_argument('disable-infobars')
 8 browser = webdriver.Chrome(chrome_options=option)
 9 browser.maximize_window()  #最大化窗口
10 
11 browser.get('https://www.xxxl.com/')
12 browser.implicitly_wait(8)  #隱式等待
13 
14 list=browser.find_elements_by_css_selector('.home-recommend-goods.home-hot-goods ul.grid-list div.grid-title')#CSS定位
15 for i in list:
16     log = i.text
17     print(log)  #打印所有
18 
19 browser.quit()

 robotframework代碼:

 

CSS定位可以在瀏覽器中提前查看是否是自己想要的。如,定位百度文本框:

瀏覽器調試窗口,ctrl+f可以輸入定位器。鼠標放在定位的地方,上面也會顯示定位表達式,但是是否是唯一,最好檢查一下。

 


免責聲明!

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



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