web自动化测试理论之selenium八大定位

一、ID定位

概念:通过元素的id属性来定位元素。

前置:所要定位的元素必须有id属性

方法:driver.find_element_by_id(id属性值)

"""需求:打开注册A.html页面,完成以下操作1).使用id定位,输入用户名:admin2).使用id定位,输入密码:1234563).3秒后关闭浏览器窗口
"""
# 导包
from time import sleep
from selenium import webdriver# 创建浏览器驱动
driver = webdriver.Chrome()
# 打开测试网址
driver.get('file:///C:/Users/Desktop/UITest/%E6%B3%A8%E5%86%8CA.html')
# 定位元素,调用模拟操作方法
driver.find_element_by_id('userA').send_keys('admin')
driver.find_element_by_id('passwordA').send_keys('123456')
# 暂停3秒看效果
sleep(3)
# 操作完毕关闭浏览器
driver.quit()

二、Name定位

概念:通过元素的name属性来定位元素。

前置:所要定位的元素必须有name属性。

方法:driver.find_element_by_name(name属性值)

特点:当前页面可以重复

由于name属性值可以重复,所以使⽤时需要查看是否为唯⼀

# 定位元素,调用模拟操作方法
driver.find_element_by_name('userA').send_keys('admin')
driver.find_element_by_name('passwordA').send_keys('123456')

三、class_name 定位

概念:通过元素的class_name属性来定位元素。

前置:所要定位的元素必须有class类名属性。

方法:driver.find_element_by_class_name(class属性值)

特点: class属性值可以有多个值

说明:如果标签有多个class值,使⽤任何⼀个都可以。如:c1

<p><label for="emailA">电子邮件A:</label><input type="emailA" placeholder="电子邮箱A"  class="c1 c2 c3">
</p>
# 定位元素,调用模拟操作方法
driver.find_element_by_class_name('telA').send_keys('18611111111')
driver.find_element_by_class_name('c1').send_keys('123@qq.com')

四、Tag_name 定位

概念:通过元素的标签名来定位元素。

方法:driver.find_element_by_tag_name(标签名)

特点:重复性高,不建议使用 

提示: 如果⻚⾯存在多个相同标签,默认返回第⼀个。

# 定位元素,调用模拟操作方法
# 使用标签名定位确认符合条件的元素是第几个?如果需要获取所有的相同标签,使用查找一组元素的方法
driver.find_element_by_tag_name('input').send_keys('admin')

五、link_text 定位

概念:专门用来定位超链接元素(<a></a>标签)

方法:driver.find_element_by_link_text(超链接的全部文本内容)

特点: 传⼊的链接⽂本,必须全部匹配,不能模糊

提示:获取要定位超链接文本类容,用拷贝的形式,定位元素

# 定位元素,调用模拟操作方法
driver.find_element_by_link_text('访问 新浪 网站').click()

使用link_text定位图片标记的元素会有什么问题?

代码过长

定位不到

六、partial_link_text 定位

概念:使用局部文本来定位元素:

局部文本:

方法:driver.find_element_by_partial_link_text(超链接的局部文本内容)

从字符串任意位置开始,一截连续字符集。

提示:获取要定位超链接文本部分类容(能表示该元素唯一性),用拷贝的形式,定位元素

# 定位元素,调用模拟操作方法
# # 获取要定位超链接文本部分类容(能表示该元素唯一性),用拷贝的形式,定位元素
driver.find_element_by_partial_link_text('新浪').click()

扩展- 查找一组元素

含义:定位所有符合条件的元素

Return:返回的数据为所有符合条件的元素对象的列表

说明:返回列表格式,要使⽤需要添加下标或遍历。

⽅法: driver.find_elements_by_xxxx()

提示: ⼋⼤元素定位⽅法,都可以使⽤⼀组元素定位,如果没有搜索到符合标签,返回空列表

在定位元素时,如果出现下面的问题:

1、定位到多个符合条件的元素

2、且所需元素定位元素不是第一个

如何从返回的列表中取某一个的元素对象?

定位符合条件的一组元素后,通过下标取指定的元素对象。

# 需求:使用定位一组元素的方法 driver.find_elements_by_tag_name()将注册A的信息进行填写
# 查找所有的input标签
inputs = driver.find_elements_by_tag_name('input')
inputs[0].send_keys('admin')
inputs[1].send_keys('123456')
inputs[2].send_keys('18611111111')
inputs[3].send_keys('123@qq.com')# 动态填写值
for i in inputs:if i.get_attribute('name') == 'userA':i.send_keys('admin')elif i.get_attribute('type') == 'password':i.send_keys('123456')elif i.get_attribute('id') == 'telA':i.send_keys('18611111111')else:i.send_keys('123@qq.com')

在定位元素时,可以利用:

元素自身的信息:id、name、class、tag_name、文本,所有属性都可以来定位

元素的层级关系:xpath定位、css定位

七、Xpath定位

概念;XML Path简称,用于在XML文档中查找元素信息的语言。

方法:driver.find_element_by_xpath(xpath表达式)

XML特点:

1、层级结构

2、都有标签组成

3、标签都有自己属性信息

Xpath定位策略(方法):

路径定位

属性定位

属性与逻辑结合

层级与属性结合

1、Xpath定位-路径定位

绝对路径

概念:从最外层元素到指定元素之间所有经过的元素层级的路径。 (从根⽬录开始,逐级查找标签)

表达式写法:对路径以/html根节点开始,使用 / 来分隔元素层级。

如:/html/body/form/div/fieldset/center/p[1]/input  定位账号A的输入框

绝对路径对界面依赖强,不建议使用

相对路径:

概念:从目标定位元素的任意层级的上级元素开始到目标元素所经过的层级的路径。

表达式写法:以//开始,后续每个层级都使用/来分隔。

如://fieldset//p[1]//input    或者//fieldset//p[1]/input 定位账号A的输入框

# 绝对路径
el = driver.find_element_by_xpath('/html/body/form/div/fieldset/center/p[1]/input')
el.send_keys('admin')
sleep(2)
# 清除元素
el.clear()
# 相对路径
driver.find_element_by_xpath('//fieldset//p[1]//input').send_keys('123')

2、Xpath定位-属性定位

概念:利用元素的属性来进行定位。

示例:

//input[@type='submit']

//*[@value='提交']

元素的属性有很多,挑选哪个属性来定位呢?

挑选元素所特有的

挑选较为常用的:id、name、class、value......

总之:尽量挑选能精准定位到唯一元素的属性

#  利用元素的属性信息精准定位用户名输入框,并输入:admin
el = driver.find_element_by_xpath('//input[@placeholder="账号A"]').send_keys('admin')

3、Xpath定位-属性与逻辑结合

概念:利用元素的多个属性来进行定位。

示例://input[@value='提交' and @class='banana']

利用单个属性信息定位不到元素了。

# 利用属性与逻辑结合在test1输入框输入:admin
driver.find_element_by_xpath('//input[@class="login" and @name="user"]').send_keys('admin')

单属性: //*[@属性名='属性值']

多属性: //*[@属性名='属性值' and @属性名='属性值']

提示:可以使⽤任何属性。

4、Xpath定位-属性与层级结合

利用多个属性信息定位不到元素了。

利用层级与属性结合在test1输入框输入:admin

# 利用层级与属性结合在用户名输入框输入:admin
# 层级和属性结合
driver.find_element_by_xpath('//p[@id="p1"]/input').send_keys('admin')

说明: 如果元素现有的属性不能唯⼀匹配,需要结合层级使⽤

语法:

//⽗标签/⼦标签       必须为直属⼦级

//⽗标签[@属性='值']//后代标签      ⽗和后代之间可以跨越元素

5、Xpath定位 -- 延伸扩展

text()='xxx' 、contains(@attribute,'xxx')   、starts-with(@attribute,'xxx')

//*[text()="xxx"]           文本内容是xxx的元素

//*[contains(@attribute,'xxx')]    属性中含有xxx的元素

//*[starts-with(@attribute,'xxx')]    属性以xxx开头的元素

driver.find_element_by_xpath('//*[contains(@placeholder,"账号")]').send_keys('admin')sleep(2)
driver.find_element_by_xpath('//a[text()="访问 新浪 网站"]').click()
driver.find_element_by_xpath('//a[starts-with(@href,"http")]').click()

xpath综合练习

"""1. 打开Tpshop首页;2. 使用 Xpath 文本定位策略定位登陆超链接,并点击;3. 使用 Xpath 属性定位策略定位用户名输入框,输入:15800000001;4. 使用 Xpath 属性包含定位策略定位密码输入框,输入:123456;5. 使用 Xpath 属性与逻辑结合策略定位验证码输入框,输入:8888;6. 使用 Xpath 层级与属性结合策略定位登陆按钮,并点击;每步操作之后暂停2s
"""# 1、导包
from time import sleep
from selenium import webdriver# 2、实例化浏览器对象
driver = webdriver.Chrome()# 3、打开浏览器
driver.get('http://tpshop-test.itheima.net/')
driver.find_element_by_xpath('//*[text()="登录"]').click()
driver.find_element_by_xpath('//*[@placeholder="手机号/邮箱"]').send_keys('15800000001')
driver.find_element_by_xpath('//*[contains(@placeholder,"密码")]').send_keys('123456')
driver.find_element_by_xpath('//input[@placeholder="验证码" and  @name="verify_code"]').send_keys('8888')
driver.find_element_by_xpath('//*[@class="login_bnt"]/a').click()
# 4、观察对象
sleep(2)# 5、关闭浏览器
driver.quit()

八、CSS定位

css概念:(Cascading Style Sheets)是一种语言,用来描述HTML 元素的显示样式。

css选择器:一种表达式,可以找到HTML中的标签元素。

CSS定位概念:selenium利用选择器定位元素的定位方式。

CSS定位方法:driver.find_element_by_css_selector(选择器表达式) 

特点:

速度更快

写法更简洁

策略(方法):

ID选择器

类选择器

元素选择器

属性选择器

层级选择器

"""使用css定位完成下面操作需求:打开注册A.html页面,完成以下操作1).使用CSS定位方式中id选择器定位用户名输入框,并输入:admin 2).使用CSS定位方式中属性选择器定位密码输入框,并输入:123456 3).使用CSS定位方式中class选择器定位电话号码输入框,并输入:18600000000 4).使用CSS定位方式中元素选择器定位注册按钮,并点击
"""# ⽤户名 id选择->#id属性值
driver.find_element_by_css_selector('#userA').send_keys('admin')
# 密码 属性选择器->[属性名='属性值']
driver.find_element_by_css_selector('[name="passwordA"]').send_keys('123456')
# 电话 类选择器->.class属性值
driver.find_element_by_css_selector('.telA').send_keys('18600000000')
# 电子邮件   后代选择器
driver.find_element_by_css_selector('p>#emailA').send_keys('123@qq.com')
sleep(2)
# 确定 标签选择器-标签名
driver.find_element_by_css_selector('button').click()

1、CSS定位  - ID选择器

说明:利用元素ID属性来选择

格式:#id属性值

前置: 标签必须id属性

2   CSS定位  -  类选择器

说明:利用元素class属性值来选择

格式:.class属性值

前置: 标签必须class属性

3、CSS定位  - 元素选择器 / 标签选择器

语法: 标签名

提示: 注意标签是否在⻚⾯中唯⼀,否则返回单个或所有

4、CSS定位  -  属性选择器

语法: [属性名='属性值']

说明: 标签任意属性都可以

5、CSS定位  -  层级选择器

后代关系包含了父子关系,一般只需记忆后代关系即可

父子关系:

概念:根据元素的父子关系来选择元素

表达式写法:element1>element2

如:p[id="p1"]>input

⽗⼦关系: 选择器>选择器 如: #p1>input

后代关系:

后代关系: 选择器 选择器 如: #p1 input

选择器使⽤任何⼀种css选择器(id选择器、类选择器、属性选择器、标签选 择器)都可以

概念:根据元素的上级元素来选择元素(只要是目标元素上层元素即可)

表达式写法:element1 element2     注意中间有空格

如:p[id="p1"] input

案例:使用CSS定位方式中的层级选择器定 位用户名输入框,并输入:admin

# 使用CSS定位方式中的层级选择器定位用户名输入框,并输入:admin
# 后代关系   中间用空格隔开
driver.find_element_by_css_selector('p[id="p1"] input').send_keys('admin')

6、css定位 - 延伸扩展

利用局部属性值定位元素

tagName[attribute*='局部属性值']

标签名[属性=‘局部属性值’]

# 利用局部属性定位方式定位用户名输入框输入:admin
driver.find_element_by_css_selector('input[placeholder*="账号"]').send_keys('admin')

注意:在带有属性值的时候,注意单引号、多引号的合理使用,外单(单引号)内双(双引号)

查找元素:find_element()

方法:driver.find_element(by=By.所要选择定位方式的类属性,value=所选择定位方式所要求的值)

为了查找元素⽅法的封装

from selenium.webdriver.common.by import By"""需求:打开注册A.html页面,完成以下操作1).使用id定位用户名输入框,并输入:admin 2).使用name定位密码输入框,并输入:123456 3).使用class定位电话号码输入框,并输入:18600000000 4).使用标签名定位注册按钮,并点击
"""
driver.find_element(By.ID, 'userA').send_keys('admin')
driver.find_element(By.NAME, 'passwordA').send_keys('123456')
driver.find_element(By.CLASS_NAME, 'telA').send_keys('18600000000')
sleep(2)
driver.find_element(By.TAG_NAME, 'button').click()

八大元素定位方式总结

结论:

1、⾸推css定位,原因执⾏速度快。

①如果有ID属性,使⽤#id

②没有id属性,使⽤其他有的属性(能代表唯⼀的属性)

③如果属性都带不了唯⼀,使⽤层级

2、如果css解决不了,使⽤xpath。

元素操作

元素=driver.find_element()

点击:

元素.click()

输⼊:元素.send_keys(内容)

清空:元素.clear()

# 3、查找操作元素
driver.find_element(By.CSS_SELECTOR, "#userA").send_keys("admin")
driver.find_element(By.CSS_SELECTOR, "[name='passwordA']").send_keys("123456")
driver.find_element(By.CSS_SELECTOR, ".telA").send_keys("18611111111")
driver.find_element(By.CSS_SELECTOR, "[placeholder*='邮箱']").send_keys("123@qq.com")
# 修改电话
sleep(3)
driver.find_element(By.CSS_SELECTOR, ".telA").clear()
driver.find_element(By.CSS_SELECTOR, ".telA").send_keys("18600000000")
sleep(3)
# 点击注册
driver.find_element(By.CSS_SELECTOR, "button").click()

元素获取方法:

获取⼤⼩: 元素.size

获取⽂本: 元素.text

获取属性: 元素.get_attribute('属性名')

判断元素是否可⻅: 元素.is_displayed()

判断元素是否可⽤: 元素.is_enabled()

判断元素是否选中: 元素.is_selected()

# 获取⼤⼩ 元素.size
user = driver.find_element(By.CSS_SELECTOR,"#userA").size
print("⽤户名输⼊框的⼤⼩:",user)
# 获取内容 元素.text
a_text = driver.find_element(By.TAG_NAME,"a").text
print("第⼀个a标签的⽂本:",a_text)
# 获取属性 超连接地址
a_href = driver.find_element(By.TAG_NAME,"a").get_attribute("href")
print("第⼀个a标签的链接:",a_href)
# 判断span标签是否可⻅ 元素.is_displayed
span = driver.find_element(By.TAG_NAME,"span").is_displayed()
print("span是否可⻅:",span)
# 判断取消按钮是否可⽤ is_enabled
btn_is_enabled = driver.find_element(By.CSS_SELECTOR,"#cancelA").is_enabled()
print("取消按钮是否可⽤:",btn_is_enabled)
# 旅游是否选中 is_selected
is_selected = driver.find_element(By.CSS_SELECTOR,"#lyA").is_selected()
print("旅游是否被选中:",is_selected)

web自动化测试理论之selenium八大定位 -(2)相关推荐

  1. Selenium 八大定位,滚雪球学 Python 番外系列

    今天是持续写作的第 24 / 100 天. 如果你有想要交流的想法.技术,欢迎在评论区留言. 今天学点简单又单调了,Selenium 八大定位. 橡皮擦有几个朋友在群里说:唉,橡皮擦,你咋又写基础的东 ...

  2. Web自动化测试理论知识

    Web 自动化理论知识 1.自动化测试概述 概念:用工具代替/辅助人工完成完成软件测试活动的过程 特点:     可以对程序的新版本自动执行回归测试     可以执行一些手工测试困难或不可能进行的测试 ...

  3. 从零开始编写Web自动化测试脚本(一)--Selenium+WebDriver环境搭建

    第一章 Selenium+WebDriver环境搭建 第二章 Selenium定位方式 第三章 元素常用属性 第四章 自动化中的三种等待 第五章 自动化浏览器设置及句柄.窗口切换操作 第六章 鼠标.键 ...

  4. 【python中selenium八大定位方法解析】

    1.python模拟人,打开浏览器,操做页面,验证系统的功能是否正确() 2.web自动化应用场景:1.冒烟测试(稳定的业务场景,主流程确认系统可用) 2.回归测试(稳定的业务场景,页面改的小) 场景 ...

  5. web自动化测试理论之浏览器操作 -(3)

    浏览器操作 设置浏览器显示范围: 1.窗口最大化 dirver.maxmize_window() 2.设置窗口大小 dirver.set_window_size(width, height) 3.设置 ...

  6. UI自动化测试python明明selenium元素定位了却不能点击执行

    题外扩展统计问题点收集 问题1明明元素定位了却不能点击 答在代码点击[首页][地址管理]行前放刷新页面代码 driver.refresh()#刷新页面 问题2明明元素定位了却还不能点击2[增加新地址] ...

  7. Web自动化测试二:selenium打开和登录浏览器(火狐、IE、chrome)

    案例1:打开火狐浏览器,登录OutLook网页版 public class Test1 { WebDriver driver=null; String url="https://exchan ...

  8. selenium - web 自动化测试

    1.什么是自动化 有效的减少人力的消耗, 同时提高生活的质量. 通过自动化测试有效减少人力的投入, 同时提高了测试的质量和效率. 1.1 为什么需要自动化测试 测试人员有个环节叫做回归测试. 回归测试 ...

  9. Web自动化测试简介及web自动化测试实战交教程

    一.认识web自动化测试 1.什么是自动化测试? 自动化测试的概念: 软件自动化测试就是通过测试工具或者其他手段,按照测试人员的预定计划对软件产品进行自动化测试,他是软件测试的一个重要组成部分,能够完 ...

最新文章

  1. golang for循环 使用多个变量
  2. Python中有几种办法交换两个变量的值?
  3. 2.6 MYSQL的输出格式
  4. MongoDB启动报错
  5. HYSBZ - 2160 拉拉队排练(回文自动机)
  6. Java创建对象详解
  7. 力扣530. 二叉搜索树的最小绝对差(JavaScript)
  8. Javascript中的null、undefined、NaN
  9. Ubuntu 安装极点五笔 for ibus
  10. MySQL数据库性能优化的关键参数(转)
  11. windows查找端口占用情况
  12. 绘制Python代码的UML图
  13. 王通讲生物信息学学习方法
  14. JavaMaven【二、目录结构HelloMaven】
  15. CMake 使用总结(转载)
  16. python正则匹配ip_python实战系列之正则获取IP地址(八)
  17. DirectX11学习笔记01
  18. 【金猿人物展】数睿数据创始人兼CEO穆鸿:大数据价值创造关键在于应用普惠...
  19. mantis 重启mysql_Mantis -- linux
  20. linux raid5模拟数据丢失,Linux服务器右异步RAID-5数据恢复实例分析

热门文章

  1. 华为数字芯片实习生面试经验
  2. Hyperledger Fabric 2.x 单机部署多节点网络
  3. Wacom数位板在Mac 10.15以上系统驱动安装不支持
  4. LabVIEW——清空文件夹
  5. IRIG-B高精度B码解码 同步精度10ns
  6. BIM模型文件下载——某高层办公楼Revit模型
  7. 演说演讲PPT模板推荐
  8. C++ ORM - fg100emil的专栏 - 博客频道 - CSDN.NET
  9. 教大家如何区分屏蔽数据线的好坏
  10. 干法读书心得:第一章 7、坚持“愚直地、认真地、诚实地”工作