大部分人在使用selenium定位元素時,用的是xpath定位,css定位往往被忽略掉了,其實css定位也有它的價值,css定位更快,語法更簡潔
常見符號:
#表示 id選擇器
.表示 class選擇器
>表示子元素,層級
一個空格也表示子元素,但是是所有的後代子元素,相當於 xpath 中的相對路徑
css可以通過元素的id、class、標籤這三個常規屬性直接定位到
如下是百度輸入框的的html程式碼: <input id="kw" class="s_ipt" type="text" autocomplete="off" maxlength="100" name="wd"/>
css用#號表示id屬性,如:#kw
css用.表示class屬性,如:.s_ipt
css直接用標籤名稱,無任何標示符,如:input
css可以通過標籤、class、id這三個常規屬性定位,也可以通過其它屬性定位
以下是定位其它屬性的格式[name=wd] [autocomplete='off'][maxlength='255']
css可以通過標籤與屬性的組合來定位元素
input.s_ipt input#kw input[id='kw']
//form的id屬性form#form>span>input //form的class屬性form.fm>span>input
css也可以通過索引來定位子元素
Select控制元件第三個Opel #select>select>option:nth-child(3)CheckBox第一個Volvo #checkbox>input:nth-child(1)CheckBox第二個Saab #checkbox>input:nth-child(4)RadioBox第二個Saab #radio>input:nth-child(4)
css同樣也可以實現邏輯運算,同時匹配兩個屬性,跟xpath不一樣
[type='checkbox'][name='checkbox1']
拿百度的搜尋方塊來具體看看CSS定位
定位輸入框
type selector driver.find_element_by_css_selector('input')id 定位 driver.find_element_by_css_selector('#kw')class 定位 driver.find_element_by_css_selector('.s_ipt')其他屬性定位 driver.find_element_by_css_selector('[name='wd']')driver.find_element_by_css_selector("[type='text']")
id組合屬性定位 driver.find_element_by_css_selector("input#kw")class組合屬性定位 driver.find_element_by_css_selector("input.s_ipt")其他屬性組合定位 driver.find_element_by_css_selector("input[name='wd']")僅有屬性名,沒有值也可以 driver.find_element_by_css_selector("input[name]")兩個其他屬性組合定位 driver.find_element_by_css_selector("[name='wd'][autocomplete='off']")
模糊匹配屬性值方法
1>屬性值由多個空格隔開,匹配其中一個值的方法 driver.find_element_by_css_selector("input[class~='btn']")2>匹配屬性值為字串開頭的方法 driver.find_element_by_css_selector("input[class^='btn']")3>匹配屬性值字串結尾的方法 driver.find_element_by_css_selector("input[class$='s_btn']")
CSS
css可以通過元素的id、class、標籤這三個常規屬性直接定位
①. css用#號表示id屬性,如:
id=「kw」 可以寫成:#kw
②. css用.表示class屬性,如:
class="s_ipt"可以寫成:.s_ipt
③. css直接用標籤名稱,無任何識別符號,如:input
Xpath
xpath也可以通過元素的id、name、class這些屬性定位
①. 用xpath通過id屬性定位
driver.find_element(By.XPATH,"//[@id=‘kw’]")
②. 用xpath通過name屬性定位
driver.find_element(By.XPATH,"//[@name=‘wd’]")
③. 用xpath通過class屬性定位
driver.find_element(By.XPATH,"//*[@class=‘s_ipt’]")
CSS
css除了上述以外,也可以通過其他屬性定位
①. css通過name屬性定位:
driver.find_element(By.CSS_SELECTOR,"[name=‘wd’]")
②. css通過autocomplete屬性定位:
driver.find_element(By. CSS_SELECTOR,"[autocomplete=‘off’]")
③.css通過type屬性定位:
driver.find_element(By.CSS_SELECTOR,"[type=‘text’]")
Xpath
沒有上述屬性,可以通過其他屬性定位
driver.find_element(By.XPATH,"//*[@autocomplete=‘off’]")
CSS
css頁可以通過標籤與屬性的組合來定位元素
①. css通過標籤與class屬性的組合定位driver.find_element(By.CSS_SELECTOR,「input.s_ipt」)
②. css通過標籤與id屬性的組合定位driver.find_element(By.CSS_SELECTOR,「input#kw」)
③. css通過標籤與其他屬性組合定位driver.find_element(By.CSS_SELECTOR,「input[id=‘kw’]」)
Xpath
1、如果同一個屬性,同名的比較多,可以通過標籤篩選
①. 用xpath通過其他屬性定位driver.find_element(By.XPATH,"//input[@autocomplete=‘off’]")
②. 用xpath通過id屬性定位driver.find_element(By.XPATH,"//input[@id=‘kw’]")
③. 用xpath通過name屬性定位driver.find_element(By.XPATH,"//name[@id=‘wd’]")
CSS
如://form[@id=‘form’]/span/input和//form[@class=‘fm’]/span/input
①. css通過層級關係定位driver.find_element(By.CSS_SELECTOR,「form#form>span>input」)
②. css通過層級關係定位driver.find_element(By.CSS_SELECTOR,「form.fm>span>input」)
Xpath
1、如果一個元素,他的屬性不明顯,無法直接定位,可以先找到他的父元素,找到父元素,再找下一級就能定位
①. 通過定位父元素來定位input輸入框driver.find_element(By.XPATH,"//span[@id=‘s_kw_wrap’]/input")
②. 通過定位爺元素來定位input輸入框driver.find_element(By.XPATH,"//form[@id=‘form’]/span/input")
CSS
1、css也可以通過索引option:nth-child(1)來定位子元素
①. 選擇第一個子元素driver.find_element(By.CSS_SELECTOR,「select#nr>option:nth-child(1)」)
②. 選擇第二個子元素driver.find_element(By.CSS_SELECTOR,「select#nr>option:nth-child(2)」)
③. 選擇第三個子元素driver.find_element(By.CSS_SELECTOR,「select#nr>option:nth-child(3)」)
Xpath
1、可以通過排序定位
①. 用xpath定位第一位driver.find_element(By.XPATH,"//select[@id=‘nr’]/option[1]")
②. 用xpath定位第二位driver.find_element(By.XPATH,"//select[@id=‘nr’]/option[2]")
③. 用xpath定位第三位driver.find_element(By.XPATH,"//select[@id=‘nr’]/option[3]")
CSS
driver.find_element(By.CSS_SELECTOR,「input:contains(‘kw’)」)
Xpath
1、xpath強大的模糊匹配
2、by_partial_link,模糊匹配定位
driver.find_element(By.XPATH,"//*[contains(text(),‘hao123’)]")
自動化測試Python+Selenium中對於web測試定位頁面元素的兩種主流XPATH和CSS定位方式
XPATH定位和CSS定位很相似,XPATH功能更強大一些,但CSS定位方式速度更快,但是某些瀏覽器不支援CSS定位,並且一般在自動化測試過程中使用xpath定位方式要比css更普遍
(學習視訊分享:)
以上就是你必須瞭解Selenium使用CSS定位總結的詳細內容,更多請關注TW511.COM其它相關文章!