python学习的一个定位_python学习之——selenium元素定位
web自動(dòng)化測(cè)試按步驟拆分,可以分為四步操作:定位元素,操作元素,獲取返回結(jié)果,斷言(返回結(jié)果與期望結(jié)果是否一致),最后自動(dòng)出測(cè)試報(bào)告。
其中定位元素尤為關(guān)鍵,此篇是使用webdriver通過頁(yè)面各個(gè)元素的屬性值定位對(duì)象。
步驟:
一:環(huán)境準(zhǔn)備
1.瀏覽器選擇:Firefox
2.安裝插件:Firebug和FirePath(設(shè)置》附加組件》搜索:輸入插件名稱》下載安裝后重啟瀏覽器)
3.安裝完成后,頁(yè)面右上角有個(gè)小爬蟲圖標(biāo)
4.快速查看xpath插件:XPath Checker這個(gè)可下載,也可以不用下載
5.插件安裝完成后,點(diǎn)開附加組件》擴(kuò)展,有firebug、firepath、xpath checker已經(jīng)安裝完成
二:元素定位
通過firebug查看對(duì)象的屬性值,根據(jù)webdriver提供的元素定位方法,定位。
其中:selenium的webdriver提供了八種基本的元素定位方法,前面六種是通過元素的屬性來直接定位的,后面的xpath和css定位更加靈活。
1.通過id定位:find_element_by_id()
2.通過name定位:find_element_by_name()
3.通過class定位:find_element_by_class_name()
4.通過tag定位:find_element_by_tag_name()
5.通過link定位:find_element_by_link_name()
6.通過partial_link定位:find_element_by_partial_link_name() ?超鏈接名稱模糊匹配方式
7.通過xpath定位:find_element_by_xpath()
8.通過css定位:find_element_by_css_name()
通過xpath定位:
1.如果一個(gè)元素它既沒有id、name、class屬性也不是超鏈接,或者說它的屬性很多重復(fù)的,這個(gè)時(shí)候就可以用xpath解決
2.xpath是一種路徑語(yǔ)言,firepath插件查看一個(gè)元素的xpath,進(jìn)行使用定位
通過css定位:
1.css是另外一種語(yǔ)法,比xpath更為簡(jiǎn)潔,先學(xué)會(huì)如何用工具查看
2.打開FirePath插件選擇css,查看使用
實(shí)踐:
#coding=utf-8
# selenium的webdriver元素定位
from selenium import webdriver
import time
driver = webdriver.Firefox()
driver.get("https://www.baidu.com/")
time.sleep(5)
driver.find_element_by_id("kw").send_keys("python")
time.sleep(3)
driver.find_element_by_id("kw").clear()
time.sleep(3)
#點(diǎn)擊百度首頁(yè)的超鏈接
driver.find_element_by_link_text("百度首頁(yè)").click()
time.sleep(3)
#點(diǎn)擊登錄按鈕
driver.find_element_by_xpath(".//*[@id='u1']/a[7]").click()
time.sleep(3)
總結(jié)
以上是生活随笔為你收集整理的python学习的一个定位_python学习之——selenium元素定位的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 3D变换矩阵的分解公式
- 下一篇: python马尔科夫链蒙特卡洛(MCMC