Selenium2+python自動化45-18種定位方法(find_elements)


前言

江湖傳言,武林中流傳八種定位,其中xpath是寶刀屠龍,css是倚天劍。

除了這八種,其實還有十種定位方法,眼看就快失傳了,今天小編讓失傳已久的定位方法重出江湖!

一、十八種定位方法

前八種是大家都熟悉的,經常會用到的

使用webdriver.的find_element方法

self.driver.find_element()

八種定位方法統一使用的是:self.find_element(by=By.XPATH,value=xpath)

1.id定位:id在HTML界面中是唯一的存在

  find_element_by_id("id定位表達式")

 

2.name定位:根據元素的name屬性來定位

  find_element_by_name(name定位表達式)


3.class定位:根據元素的class屬性來定位

  find_element_by_class_name(name定位表達式)


4.tag定位:頁面html文檔下的各種標簽,find_element_by_tag_name("input");或者find_element(by.ag_name,“元素表達式”)

   tag往往用來定義一類功能,所以通過tag識別某個元素的概率很低。任意打開一個頁面,都會發現大量的<div>、<input>、<a>等tag,所以tag name定位很少用

   find_element_by_tag_name(self, name)


5.link定位:專門用來定位文本鏈接

   find_element_by_link_text(self, link_text)


6.partial_link定位:

   find_element_by_partial_link_text(self, link_text)


7.xpath定位:

 find_element_by_xpath('元素定位表達式')  

a./:通過絕對路徑來定位

b.//:通過相對路徑來定位(建議使用相對路徑)

c.//標簽名[@屬性名='屬性值']:通過屬性定位於元素若不想指定標簽名可以通過通配符*來代替,*匹配所有元素節點

d.//標簽名[text()='xxxxxxx']:通過元素的text內容進行定位

d:函數使用:

  text():元素的text內容

  contains(@屬性/text(),value):包含函數。例:contains(@class,"XXXX")、contains(text(),"XXXX")

e.邏輯運算

  and 表示條件與。

  or 表示條件或。

  例://div[@class="XXX" and contains(@style,"display:visibility")]

f.軸運算

ancestor:祖先結點 包括父
parent:父結點
preceding: 當前元素節點標簽之前的所有結點。(html頁面先后順序)
例://div//table//td//preceding::td
preceding-sibling: 當前元素節點標簽之前的所有兄弟結點
following: 當前元素節點標簽之后的所有結點。(html頁面先后順序)
following-sibling:當前元素節點標簽之后的所有兄弟結點

 

e:層次關系

//div[@id="u1"]//a[@name="tj_login" and text()="登錄"]。用相對定位來定位
8.css定位:find_element_by_css_selector(self, css_selector)

9.By定位:driver.find_element(By.定位方式,'元素定位表達式') 

from selenium.webdriver.common.by import By     #使用By這種定位前要將By類導入

find_element(By.ID,"loginName")
find_element(By.NAME,"SubjectName")
find_element(By.CLASS_NAME,"u-btn-levred")
find_element(By.TAG_NAME,"input")
find_element(By.LINK_TEXT,"退出")
find_element(By.PARTIAL_LINK_TEXT,"退")
find_element(By.XPATH,".//*[@id='Title")
find_element(By.CSS_SELECTOR,"[type=submit]")


這八種是復數形式

 

    1. a.批量操作對象,如選中頁面上所有復選框
    2.  
      b.先獲取一組對象,再在這組對象里定位需要的的一些對象,如定位所有復選框,然后選擇最后一個


9.id復數定位find_elements_by_id(self, id_)
10.name復數定位find_elements_by_name(self, name)
11.class復數定位find_elements_by_class_name(self, name)
12.tag復數定位find_elements_by_tag_name(self, name)
13.link復數定位find_elements_by_link_text(self, text)
14.partial_link復數定位find_elements_by_partial_link_text(self, link_text)
15.xpath復數定位find_elements_by_xpath(self, xpath)
16.css復數定位find_elements_by_css_selector(self, css_selector

這兩種就是快失傳了的
find_element(self, by='id', value=None)
find_elements(self, by='id', value=None)

 


二、element和elements傻傻分不清

1.element方法定位到是是單數,是直接定位到元素

2.elements方法是復數,這個學過英文的都知道,定位到的是一組元素,返回的是list隊列

3.可以用type()函數查看數據類型

4.打印這個返回的內容看看有什么不一樣

 

三、elements定位方法

1.前面一篇已經講過find_element()的用法,看這里:

2.這里重點介紹下用elements方法如何定位元素,當一個頁面上有多個屬性相同的元素時,然后父元素的屬性也比較模糊,不太好定位。

這個時候不用怕,換個思維,別老想着一次定位到,可以先把相同屬性的元素找出來,取對應的第幾個就可以了。

3.如下圖,百度頁面上有六個class一樣的元素,我要定位“地圖”這個元素

4.取對應下標即可定位了

四、參考代碼

# coding:utf-8
from selenium import webdriver
driver = webdriver.Firefox()
driver.get("http://www.baidu.com")

# 這里是定位的單個id
element = driver.find_element_by_id("kw")
print type(element)
print element

# 這里定位是多個class
elements = driver.find_elements_by_class_name("mnav")
print type(elements)
print elements


# 這里用的css語法
s = driver.find_elements("css selector", ".mnav")
# '地圖'在第四個位置
print s[3].text
s[3].click()

# 這個寫法也是可以的
# driver.find_elements("css selector", ".mnav")[3].click()


免責聲明!

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



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