python+selenium:瀏覽器webdriver操作(1)--基本對象定位

來源:互聯網
上載者:User

標籤: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)--基本對象定位

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.