一、查看页面元素
打开浏览器,点击右键,点击“查看元素”
定位相应控件代码,先点击下面的红标,再在想定位的元素上点击即可
二、常用web元素定位方法
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_text() //根据页面元素文本定位
6、partial_link定位:find_element_by_partial_link_text() //根据页面元素模糊匹配定位
7、xpath定位:find_element_by_xpath():可以在Firefox中加xpath finder插件,方便获取Xpath
8、CSS定位:find_element_by_css_selector()
三、表格元素定位
下面提供被测网页的HTML代码如下:
<html>
<body>
<table width="400" border="1" id="table">
<tr>
<td align="left">消费项目....</th>
<td align="right">一月</th>
<td align="right">二月</th>
</tr>
<tr>
<td align="left">衣服:
<input type='checkbox'>外套</input>
<input type='checkbox'>内衣</input>
</td>
<td align="right">100元</td>
<td align="right">500元</td>
</tr>
<tr>
<td align="left">化妆品:
<input type='checkbox'>面霜</input>
<input type='checkbox'>沐浴露</input>
</td>
<td align="right">3000元</td>
<td align="right">500元</td>
</tr>
<tr>
<td align="left">食物:
<input type='checkbox'>主食</input>
<input type='checkbox'>蔬菜</input>
</td>
<td align="right">3000元</td>
<td align="right">650元</td>
</tr>
<tr>
<td align="left">总计</th>
<td align="right">7000元</th>
<td align="right">1150元</th>
</tr>
</table>
</body>
</html>
编写测试用例遍历表格所有的单元格,参考代码如下:
try:
found_element=driver.find_element_by_id("table")
execept Exception as e:
print(e)
else:
print("查找元素:")
trlist=found_element.find_elements_by_tag_name("tr")#找到该表格中所有tr并储存
for row in trlist:
tdlist=row.find_elements_by_tag_name("td")#找到该行下的所有td并储存
for col in tdlist:
print(col.text+"\t",end="")#end表示用”“代替换行符
print()#换行
finally:
driver.quit()
四、测试用例设计
用list存储需要定位的元素属性,然后定义各个方法,去根据需要调用函数方法即可。
# coding = utf-8
from time import sleep
from selenium import webdriver
count=0
idstr=[] #1.id定位元素
idstr.append("scbar_txt")#元素类型是:input
idstr.append("scbar_btn")#元素类型是:button
idstr.append("mzLogin")#元素类型是:a
idstr.append("user-menu")#元素类型是:div
idstr.append("pm_ntc")#元素类型是:a
idstr.append("mzLogout")#元素类型是:a
idstr.append("scbar_form")#元素类型是:form
idstr.append("hotHead")#元素类型是:li
def test_by_id():
for i in idstr:
global count
count+=1
try:
found_element =driver.find_element_by_id(i)
except:
print("测试编号"+str(count)+",id:" + i + "定位失败")
else:
print("测试编号"+str(count)+",id:" + i + "定位方式测试通过")
xpathstr=[] #2.XPATH定位元素
xpathstr.append("//*[@id='scbar_txt']")
xpathstr.append("//*[@id='scbar_btn']")
xpathstr.append("//*[@id='mzLogin']")
xpathstr.append("//*[@id='pm_ntc']")
xpathstr.append("//*[@id='scbar_form']")
xpathstr.append("//*[@id='hotHead']")
xpathstr.append("//*[@uid='111241623']")#img
def test_by_xpath():
for i in xpathstr:
global count
count += 1
try:
found_element =driver.find_element_by_xpath(i)
except:
print("测试编号"+str(count)+",xpath:" + i + "定位失败")
else:
print("测试编号"+str(count)+",xpath:" + i + "定位方式测试通过")
linkstr=[] #3.link定位
linkstr.append("官网")#元素:h3
linkstr.append("综合讨论")
linkstr.append("加入我们")
linkstr.append("了解魅族")
linkstr.append("联系我们")
def test_by_linktext():
for i in linkstr:
global count
count += 1
try:
found_element =driver.find_element_by_link_text(i)
except:
print("测试编号"+str(count)+",linktext:"+i+"定位失败")
else:
print("测试编号"+str(count)+",linktext:"+i+"定位方式测试通过")
classnamestr=[] #4.classname定位
classnamestr.append("pg_index") #body
classnamestr.append("border-wrap")
classnamestr.append("head-nav-r")
classnamestr.append("app-down-content")
classnamestr.append("bbs-logo")
def test_by_classname():
for i in classnamestr:
global count
count += 1
try:
found_element =driver.find_element_by_class_name(i)
except:
print("测试编号"+str(count)+",class_name: "+i+"定位失败")
else:
print("测试编号"+str(count)+",class_name: "+i+"定位方式测试通过")
namestr=[] #5.name定位
namestr.append("keywords") #元素类型:meta
namestr.append("author") #元素类型:meta
namestr.append("application-name")#元素类型:meta
namestr.append("mod")#元素类型:meta
namestr.append("srchtxt")#元素类型:meta
def test_by_name():
for i in namestr:
global count
count += 1
try:
found_element =driver.find_element_by_name(i)
except:
print("测试编号"+str(count)+",name: "+i+"定位失败}")
else:
print("测试编号"+str(count)+",name: "+i+"定位方式测试通过")
if __name__ == '__main__':
# 启动浏览器
driver = webdriver.Firefox()
# 打开网站首页
driver.get('https://bbs.meizu.cn/')
sleep(1)
test_by_id()
test_by_linktext()
test_by_classname()
test_by_name()
test_by_xpath()
#层级定位1:
try:
count+=1
driver.find_element_by_xpath("//*[@id='scbar']/form/div").find_element_by_id("scbar_txt").send_keys("魅族")
#driver.find_element_by_xpath("//*[@id='hotThreadCnt']").find_element_by_link_text("魅友们你们都结婚了吗???")
except:
print("测试编号" + str(count) + ",层级" + "定位失败}")
else:
print("测试编号" + str(count) + ",层级" + "定位方式测试通过")
try:
count += 1
driver.find_element_by_xpath("//*[@id='hotThreadCnt']/tr[0]/td[1]/div")
except:
print("测试编号" + str(count) + ",表格" + "定位失败")
else:
print("测试编号" + str(count) + ",表格" + "定位方式测试通过")
sleep(2)
driver.quit()