標籤:put mon art 一個 nta 擴充 姓名 partial 定位
1.簡單對象的定位-----自動化測試的核心
對象的定位應該是自動化測試的核心,要想操作一個對象,首先應該識別這個對象。一個對象就是一個人一樣,他會有各種的特徵(屬性),如比我們可以通過一個人的社會安全號碼,姓名,或者他住在哪個街道、樓層、門牌找到這個人。那麼一個對象也有類似的屬性,我們可以通過這個屬性找到這對象。
2.webdriver提供了一系列的對象定位方法,常用的有以下幾種
- · id
- · name
- · class name
- · link text
- · partial link text
- · tag name
- · xpath
- · css selector
3.以百度輸入框的屬性資訊為例,則可以通過以下一系列方式捕獲輸入框
#coding=utf-8from selenium import webdriverimport timebrowser = webdriver.Firefox()browser.get("http://www.baidu.com")time.sleep(2)#########百度輸入框的定位方式###########通過id方式定位browser.find_element_by_id("kw").send_keys("selenium")#通過name方式定位browser.find_element_by_name("wd").send_keys("selenium")#通過tag name方式定位browser.find_element_by_tag_name("input").send_keys("selenium")#通過class name 方式定位browser.find_element_by_class_name("s_ipt").send_keys("selenium")#通過CSS方式定位browser.find_element_by_css_selector("#kw").send_keys("selenium")#通過xphan方式定位browser.find_element_by_xpath("//input[@id=‘kw‘]").send_keys("selenium")############################################browser.find_element_by_id("su").click()time.sleep(3)browser.quit()
4.分別介紹
百度輸入框的屬性如(滑鼠放在輸入框---右鍵---檢查)
(1)id/name
從可以看到有id,name屬性,則可以通過函數擷取:
id=”kw”
通過find_element_by_id("kw") 函數就是捕獲到百度輸入框
name=”wd”
通過find_element_by_name("wd")函數同樣也可以捕獲百度輸入框
(2)class name/tag name
從可以看到不止有id,name屬性,還有class(s_ipt)、tag name(標籤名--input)屬性
class="s_ipt"
通過find_element_by_class_name("s_ipt")函數捕獲百度輸入框。
<input>
input 就是標籤的名字,可以通過find_element_by_tag_name("input") 函數來定位。
(3)link text/partial link text
有時候不是一個輸入框也不是一個按鈕,而是一個文字連結,我們可以通過link
例如百度首頁右上方的貼吧連結,可以通過link方式擷取
link text
通過find_element_by_link_test("貼 吧").click()函數來定位
partial link text:部分連結定位,只用了"貼"字,一樣能找到"貼 吧"連結
通過find_element_by_link_test("貼").click()函數來定位
(4)xpath
XPath是一種在XML文檔中定位元素的語言。因為HTML可以看做XML的一種實現,所以selenium使用者可是使用這種強大語言在web應用中定位元素。
XPath擴充了上面id和name定位方式,提供了很多種可能性,如以下應用:
xpath:attributer (屬性)driver.find_element_by_xpath("//input[@id=‘kw‘]").send_keys("selenium")#input標籤下id =kw的元素 xpath:idRelative (id相關性)driver.find_element_by_xpath("//div[@id=‘fm‘]/form/span/input").send_keys("selenium")#在/form/span/input 層級標籤下有個div標籤的id=fm的元素driver.find_element_by_xpath("//tr[@id=‘check‘]/td[2]").click() # id為‘check‘ 的tr ,定位他裡面的第2個td xpath:position (位置)driver.find_element_by_xpath("//input").send_keys("selenium") driver.find_element_by_xpath("//tr[7]/td[2]").click()#第7個tr 裡面的第2個td xpath: href (水平參考)driver.find_element_by_xpath("//a[contains(text(),‘網頁‘)]").click()#在a標籤下有個文本(text)包含(contains)‘網頁‘ 的元素 xpath:linkdriver.find_element_by_xpath("//a[@href=‘http://www.baidu.com/‘]").click()#有個叫a的標籤,他有個連結href=‘http://www.baidu.com/ 的元素
(5)css
CSS(Cascading Style Sheets)是一種語言,它被用來描述HTML和XML文檔的表現。CSS使用選取器來為頁面元素繫結屬性。這些選取器可以被selenium用作另外的定位策略。
CSS的比較靈活可以選擇控制項的任意屬性
取id屬性:
如屬性資訊為:<input id="kw" class="s_ipt" type="text" maxlength="100" name="wd" autocomplete="off">
通過find_element_by_css_selector("#kw")函數來定位
取name屬性:
如屬性資訊為:<a href="http://news.baidu.com" name="tj_news">新 聞</a>
通過find_element_by_css_selector("a[name=\"tj_news\"]").click()函數來定位
取title屬性:
如屬性資訊為:<a onclick="queryTab(this);" mon="col=502&pn=0" title="web" href="http://www.baidu.com/">網頁</a>
通過find_element_by_css_selector("a[title=\"web\"]").click()函數來定位
python+selenium:瀏覽器webdriver操作(1)--基本對象定位