轻松自动化---selenium-webdriver(python) (三)
http://www.testclass.net/ 测试教程网,专业的selenium 学习网站。
本节重点:
- 简单对象的定位
-----自动化测试的核心
对象的定位应该是自动化测试的核心,要想操作一个对象,首先应该识别这个对象。一个对象就是一个人一样,他会有各种的特征(属性),如比我们可以通过一个人的身份证号,姓名,或者他住在哪个街道、楼层、门牌找到这个人。
那么一个对象也有类似的属性,我们可以通过这个属性找到这对象。
定位对象的目的一般有下面几种
· 操作对象
· 获得对象的属性,如获得测试对象的class属性,name属性等等
· 获得对象的text
· 获得对象的数量
webdriver提供了一系列的对象定位方法,常用的有以下几种
- · id
- · name
- · class name
- · link text
- · partial link text
- · tag name
- · xpath
- · css selector
我们可以看到,一个百度的输入框,可以用这么用种方式去定位。
#coding=utf-8from selenium import webdriver import 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()
OK~!通过上面一个例子,就帮我们展示了几种定位方式,下面来介绍每种定位方式:
id 和 name
id 和 name 是我们最最常用的定位方式,因为大多数控件都有这两个属性,而且在对控件的id 和name命名时一般使其有意义也会取不同的名字。通过这两个属性使我们找一个页面上的属性变得相当容易
我们通过前端工具,找到了百度输入框的属性信息,如下:
<input id="kw" class="s_ipt" type="text" maxlength="100" name="wd" autocomplete="off">
id=”kw”
通过find_element_by_id("kw") 函数就是捕获到百度输入框
name=”wd”
通过find_element_by_name("wd")函数同样也可以捕获百度输入框
tag name 和class name
从上面的百度输入框的属性信息中,我们看到,不单单只有id 和 name两个属性,比如class 和 tag name(标签名)
<input>
input 就是一个标签的名字,可以通过find_element_by_tag_name("input") 函数来定位。
class="s_ipt"
通过find_element_by_class_name("s_ipt")函数捕获百度输入框。
但是,碰下面的一组控件属性,我们就哭了。
<th width="95"></th> <th width="">文件名</th> <th class="c1">创建时间</th> <th class="c1">状态</th> <th class="c1">文件大小</th> <th class="c1">时长</th>
下面的css 和 XPath就没有上面的那么直观,如果不懂前端的话可能不太好理解
CSS定位
CSS(Cascading Style Sheets)是一种语言,它被用来描述HTML和XML文档的表现。CSS使用选择器来为页面元素绑定属性。这些选择器可以被selenium用作另外的定位策略。
CSS的比较灵活可以选择控件的任意属性,上面的例子中:
find_element_by_css_selector("#kw")
通过find_element_by_css_selector( )函数,选择取百度输入框的id属性来定义
也可以取name属性
<a href="http://news.baidu.com" name="tj_news">新 闻</a>
driver.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>
driver.find_element_by_css_selector("a[title=\"web\"]").click()
也可以是取..:
<a class="RecycleBin xz" href="javascript:void(0);">
driver.find_element_by_css_selector("a.RecycleBin").click()
虽然我也没全部理解CSS的定位,但是看上去应该是一种非常灵活和牛X 的定位方式
扩展阅读:
http://www.w3.org/TR/css3-selectors/
http://www.w3school.com.cn/css/css_positioning.asp
XPath
什么是XPath:http://www.w3.org/TR/xpath/
XPath基础教程:http://www.w3schools.com/xpath/default.asp
selenium中被误解的XPath : http://magustest.com/blog/category/webdriver/
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/ 的元素
link 定位
有时候不是一个输入框也不是一个按钮,而是一个文字链接,我们可以通过link
#coding=utf-8from selenium import webdriver import timebrowser = webdriver.Firefox()browser.get("http://www.baidu.com") time.sleep(2)browser.find_element_by_link_text("贴 吧").click() time.sleep(2) browser.quit()
一般一个那页面上不会出现相同的文件链接,通过文字链接来定位也是一种简单有效的定位方式。
Partial Link Text 定位
通过部分链接定位,这个有时候也会用到,我还没有想到很好的用处。拿上面的例子,我可以只用链接的一部分文字进行匹配:
browser.find_element_by_partial_link_text("贴").click()#通过find_element_by_partial_link_text() 函数,我只用了“贴”字,脚本一样找到了"贴 吧" 的链接
--------------------------
学习更多selenium 内容:
「功能测试自动化」汇总
轻松自动化---selenium-webdriver(python) (三)相关推荐
- Selenium WebDriver + python 自动化测试框架
目标 组内任何人都可以进行自动化测试用例的编写 完全分离测试用例和自动化测试代码,就像写手工测试用例一下,编写excel格式的测试用例,包括步骤.检查点,然后执行自动化工程,即可执行功能自动化测试用例 ...
- Selenium自动化测试Python三:WebDriver进阶
WebDriver 进阶 欢迎阅读WebDriver进阶讲义.本篇讲义将会重点介绍Selenium WebDriver API的重点使用方法,以及使用模块化和参数化进行自动化测试的设计. WebDri ...
- selenium webdriver (python)的基本用法一
阅在线 AIP 文档: http://selenium.googlecode.com/git/docs/api/py/index.html 目录 一.selenium+python 环境搭建..... ...
- python webdriver点击指令_测开系列Selenium Webdriver Python(20)--Webdriver运行原理
Webdriver运行原理 转帖请注明出处!谢谢 在开发Webdriver的自动化脚本过程中,Webdriver后台在创建WebDriver实例的过程中,先确认浏览器的原生组件中是否存在可匹配的版本. ...
- 50+道自动化/Selenium/性能/Python面试题
写在前面 公司要求招一名自动化测试,能力要求不高,1年左右自动化经验+部分性能经验即可,让我出一份题,我就百度+公司项目遇到的问题,出了一份,出题整体思路是:接口自动化问题+性能问题+规划的ui.ap ...
- selenium webdriver (python) 第一版PDF
前言 如果你是一位有python语言基础的同学,又想通过python+ selenium去实施自动化,那么你非常幸运的找到了这份文档,我也非常荣幸能为你的自动化学习之路带来一丝帮助. 其实,我在sel ...
- Appium+PythonUI自动化之webdriver 的三种等待方式(强制等待、隐式等待、显示等待)
在自动化测试脚本的运行过程中,webdriver操作浏览器的时候,对于元素的定位是有一定的超时时间,大致应该在1-3秒的样子,如果这个时间内仍然定位不到元素,就会抛出异常,中止脚本执行.我们可以通过在 ...
- 测开系列Selenium Webdriver Python(21)--元素定位2
以上学习的是element的基本属性和方法,那么验证点添加的技巧和方式是什么呢?我们知道自动化的过程就是人的手工测试的过程,在手工测试中需要人来判断业务是否达到需求要求,那么在自动化脚本中就要加入程序 ...
- Linux运行webdriver,linux - 在chrome中运行Selenium WebDriver python绑定
我在使用Selenium时遇到了问题. 对于我的项目,我必须使用Chrome. 但是,在使用Selenium启动它后,我无法连接到该浏览器. 出于某种原因,Selenium无法单独找到Chrome. ...
- selenium webdriver python 元素操作
常用操作 click 点击某个元素 driver.find_element_by_id("su").click() clear driver.find_element_by_id( ...
最新文章
- 征途linux mysql_MySql征途之mysql常用命令
- 打破数据孤岛释放数据价值,腾讯联合安全计算平台重磅出炉
- 搜索专题:问题 E: 挑战ACM迷宫
- 在Windows 7中设置Java开发环境
- vue3+typescript引入外部文件
- 忆阻尖峰神经网络中基于STDP的模式识别学习的必要条件
- 前端笔试能查吗_鹅厂微博前端实习面经
- electron 改变窗体 大小_「Science子刊」约翰·霍普金斯大学创造灰尘大小设备,可协助药物在胃肠道停留24小时之久...
- 程序员面试金典——3.3集合栈
- 【渝粤教育】21秋期末考试基础会计10258k2
- Hadoop生态圈-Azkaban实现文件上传到hdfs并执行MR数据清洗
- 【metasploit】1 渗透测试与metasploit基础介绍 [PTES|msf|armitage安装]
- Android 退出登录功能
- 写给自己的一封信--平顶山学院20届计科学生大学两年成长经历回忆
- 【对流氓软件说ByeBye】—— 恶意软件删除工具
- iOS内存扫描工具实现
- 2023年西南交通大学马克思主义理论考研上岸前辈备考经验
- 第一章 行列式(知识点部分)
- 一个五层加密过的表白恢复密码解密的过程
- 解决数组转对象后,key自动排序