這篇文章為大家帶來了關於Selenium使用CSS定位總結的相關知識,css定位也有它的價值,css定位更快,語法更簡潔,希望對大家有幫助。
大部分人在使用selenium定位元素時,用的是xpath定位,css定位往往被忽略掉了,其實css定位也有它的價值,css定位更快,語法更簡潔
一、CSS 選擇器
常見符號:
#表示id選擇器
.表示class選擇器
>表示子元素,層級
一個空格也表示子元素,但是是所有的後代子元素,相當於xpath 中的相對路徑
二、CSS:屬性定位
css可以透過元素的id、class、標籤這三個常規屬性直接定位到
如下是百度输入框的的html代码: <input>
css用#號表示id屬性,如:#kw
css用.表示class屬性,如:.s_ipt
css直接用標籤名稱,無任何標示符,如:input
三、CSS:其它屬性
css可以透過標籤、class、id這三個常規屬性定位,也可以透過其它屬性定位
以下是定位其它属性的格式[name=wd] [autocomplete='off'][maxlength='255']
四、CSS:標籤
css可以透過標籤與屬性的組合來定位元素
input.s_ipt input#kw input[id='kw']
五、CSS:層級關係
//form的id属性form#form>span>input //form的class属性form.fm>span>input
六、CSS:索引
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:邏輯運算
#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與Xpath定位的差異
屬性定位
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更普遍
(學習影片分享:css影片教學)
以上是你必須了解Selenium使用CSS定位總結的詳細內容。更多資訊請關注PHP中文網其他相關文章!

@keyframesandCSSTransitionsdifferincomplexity:@keyframesallowsfordetailedanimationsequences,whileCSSTransitionshandlesimplestatechanges.UseCSSTransitionsforhovereffectslikebuttoncolorchanges,and@keyframesforintricateanimationslikerotatingspinners.

我知道,我知道:有大量的內容管理系統選項可用,而我進行了幾個測試,但實際上沒有一個是一個,y&#039;知道嗎?怪異的定價模型,艱難的自定義,有些甚至最終成為整個&

鏈接CSS文件到HTML可以通過在HTML的部分使用元素實現。 1)使用標籤鏈接本地CSS文件。 2)多個CSS文件可通過添加多個標籤實現。 3)外部CSS文件使用絕對URL鏈接,如。 4)確保正確使用文件路徑和CSS文件加載順序,優化性能可使用CSS預處理器合併文件。

選擇Flexbox還是Grid取決於佈局需求:1)Flexbox適用於一維佈局,如導航欄;2)Grid適合二維佈局,如雜誌式佈局。兩者在項目中可結合使用,提升佈局效果。

包含CSS文件的最佳方法是使用標籤在HTML的部分引入外部CSS文件。 1.使用標籤引入外部CSS文件,如。 2.對於小型調整,可以使用內聯CSS,但應謹慎使用。 3.大型項目可使用CSS預處理器如Sass或Less,通過@import導入其他CSS文件。 4.為了性能,應合併CSS文件並使用CDN,同時使用工具如CSSNano進行壓縮。

是的,youshouldlearnbothflexboxandgrid.1)flexboxisidealforone-demensional,flexiblelayoutslikenavigationmenus.2)gridexcelstcelsintwo-dimensional,confffferDesignssignssuchasmagagazineLayouts.3)blosebothenHancesSunHanceSlineHancesLayOutflexibilitibilitibilitibilitibilityAnderibilitibilityAndresponScormentilial anderingStruction

重構自己的代碼看起來是什麼樣的?約翰·瑞亞(John Rhea)挑選了他寫的一個舊的CSS動畫,並介紹了優化它的思維過程。

CSSanimationsarenotinherentlyhardbutrequirepracticeandunderstandingofCSSpropertiesandtimingfunctions.1)Startwithsimpleanimationslikescalingabuttononhoverusingkeyframes.2)Useeasingfunctionslikecubic-bezierfornaturaleffects,suchasabounceanimation.3)For


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

Dreamweaver Mac版
視覺化網頁開發工具

SublimeText3 英文版
推薦:為Win版本,支援程式碼提示!

ZendStudio 13.5.1 Mac
強大的PHP整合開發環境

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具