WebDriver提供了八种元素定位方法,在python 语言中,方法如下:

  •  id定位:find_element_by_id("id值");id属性是唯一的。
 1 driver.find_element_by_id("account").send_keys("admin")#输入账号
 2 driver.find_element_by_id("password").send_keys("111111")#输入密码
 3 driver.find_element_by_id("btnsubmit").click()#登录
  •  name定位:find_element_by_name("name值");HTML规定name来指定元素的名称,name的属性值,在当前页面中可以不唯一。
 1 driver.find_element_by_name("account").send_keys("admin")
 2 driver.find_element_by_name("password").send_keys("111111")
 3 driver.find_element_by_name("btnsubmit").click()

find_elements_by_name("PeriodName")是因为当前页面有一组radiobutton的name值是PeriodName,所以可以用定位一组元素的方法findElements,定位出来的是结果一个list

  • class定位:find_element_by_class_name("class值");HTML规定class来指定元素的类名,用法与id、name类似。
 1 driver.find_elements_by_class_name("aopenlink")[0].click()#查看详情
 2 driver.find_elements_by_class_name("panel-tool-close")[0].click()#关闭页面
  • tag定位:find_element_by_tag_name("input");通过元素的tag name 来定位元素。

tag往往用来定义一类功能,所以通过tag识别某个元素的概率很低。任意打开一个页面,都会发现大量的<div>、<input>、<a>等tag,所以tag name定位很少用。

driver.find_element_by_tag_name("input").click()
  • link定位:find_element_by_link_name("text");通过元素标签对之间的文本信息来定位元素。
driver.find_element_by_link_text("新闻").click()
  • partial link定位:是对link定位的一种补充,当链接上的文本内容比较长的时候,可以取文本的一部分进行定位,当然这部分可以唯一地标识这个链接
1 driver.find_element_by_partial_link_text("一个很长的").click()
2 driver.find_element_by_partial_link_text("文本链接").click()

前面的几种方式都比较简单,比较理想化,但是现实往往没有那么美好;经常页面没有id,name这些属性值,class name重复性较高,link定位有针对性,那么下面介绍一下Xpath与Css定位方法:

  • XPath定位:find_element_by_xpath("");有多种定位策略:

1)绝对路径定位 ;2)利用元素属性定位; 3)层级与属性结合;4)使用逻辑运算符

>>  如果是Firefox浏览器可以使用FirePath插件自动生成xpath。

>>  如果是Chrome浏览器可以使用XpathHelper插件自动生成xpath。

1 driver.find_element_by_xpath("//*[@id=\"kw\"]").click()
2 driver.find_element_by_xpath("//*[@id=\"su\"]").click()

注意:(“//*[@id="su"]”)像这种,引号中还有引号的情况,需要转义一下写成这种:(“//*[@id=\"su\"]”)。

  • CSS定位:find_element_by_css_selector("");使用选择器来为页面元素绑定属性,可以灵活地选择控件的任意属性;一般情况定位速度要快于Xpath,但是对于初学者来说有点难度。

1)通过class属性定位:点号(".")表示通过class属性定位。

1 driver.find_element_by_css_selector(".s_ipt").click()
2 driver.find_element_by_css_selector(".bg s_btn").click()

2)通过id属性定位:("#")表示通过id定位元素。

1 driver.find_element_by_css_selector("#KW").click()
2 driver.find_element_by_css_selector("#su").click()

3)通过标签名定位:直接用标签名,不需要任何字符标识,但是标签重复概率很大,通过这种方式很难找到想要的元素。

driver.find_element_by_css_selector("input").click()

4)通过父子关系定位:下面举例中:父元素:span,查找父元素下面的所有input子元素。

driver.find_element_by_css_selector("span>input").click()

5)通过属性定位:("[]"),中括号里的属性可以唯一标识这个元素就可以;属性的值可以加引号,也可以不加

1 driver.find_element_by_css_selector("[name='kw']").click()
2 driver.find_element_by_css_selector('[type="submit"]').click()

6)组合定位:把上面的策略组合起来使用,大大加强了定位元素的唯一性。

1 driver.find_element_by_css_selector("form.fm>span>input.s_ipt").click()
2 driver.find_element_by_css_selector("form#form>span>input#kw").click()

......

  • By定位元素

  处理前面介绍的定位方法,Webdriver还有另外一套写法,即统一调用find_element()方法,通过By来声明定位的方法,并且传入定位方法的定位参数。

find_element()方法只用于定位元素。它需要两个参数,第一个参数是定位的类型,由By提供;第二个参数是定位的具体方式。

 
from selenium.webdriver.common.by import By     #在使用By定位前要将By类导入

find_element(By.ID,"kw")
find_element(By.NAME,"wd")
find_element(By.CLASS_NAME,"s_ipt")
find_element(By.TAG_NAME,"input")
find_element(By.LINK_TEXT,"新闻")
find_element(By.PARTIAL_LINK_TEXT,"新")
find_element(By.XPATH,"//*[@class='bg s_btn']")
find_element(By.CSS_SELECTOR,"span.bg s_btn wr>input#su")

Web Driver 8中定位方法 ——基于python语言的更多相关文章

  1. 《Selenium 2自动化测试实战 基于Python语言》中发送最新邮件无内容问题的解决方法

    虫师的<Selenium 2自动化测试实战 基于Python语言>是我自动化测试的启蒙书 也是我推荐的自动化测试入门必备书,但是书中有一处明显的错误,会误导很多读者,这处错误就是第8章自动 ...

  2. selenium2自动化测试实战--基于Python语言

    自动化测试基础 一. 软件测试分类 1.1 根据项目流程阶段划分软件测试 1.1.1 单元测试 单元测试(或模块测试)是对程序中的单个子程序或具有独立功能的代码段进行测试的过程. 1.1.2 集成测试 ...

  3. 《Selenium2自动化测试实战--基于Python语言》 --即将面市

    发展历程: <selenium_webdriver(python)第一版>   将本博客中的这个系列整理为pdf文档,免费. <selenium_webdriver(python)第 ...

  4. 基于python语言的tensorflow的‘端到端’的字符型验证码识别源码整理(github源码分享)

    基于python语言的tensorflow的‘端到端’的字符型验证码识别 1   Abstract 验证码(CAPTCHA)的诞生本身是为了自动区分 自然人 和 机器人 的一套公开方法, 但是近几年的 ...

  5. 关于《selenium2自动测试实战--基于Python语言》

    关于本书的类型: 首先在我看来技术书分为两类,一类是“思想”,一类是“操作手册”. 对于思想类的书,一般作者有很多年经验积累,这类书需要细读与品位.高手读了会深有体会,豁然开朗.新手读了不止所云,甚至 ...

  6. 关于《Selenium3自动化测试实战--基于python语言》

    2016年1月,机缘巧合下我出版了<Selenium2自动化测试实战--基于python语言>这本书,当时写书的原因是,大部分讲Selenium的书并不讲编程语言和单元测试框,如果想在项目 ...

  7. selenium2环境搭建----基于python语言

    selenium支持多种语言如java.c#.Python.PHP等,这里基于python语言,所以这里搭建环境时需做俩步操作: ----1.Python环境的搭建 ----2.selenium的安装 ...

  8. Selenium八种基本定位方式---基于python

    from selenium import  webdriver driver=webdriver.Firefox() driver.get("https://www.baidu.com&qu ...

  9. 部署基于python语言的WEB发布环境

    一.部署说明 1.python语言介绍 python简介 2.实验环境 实验机器:Vmware虚拟机 8核10G 网卡:桥接模式 系统:centos7.5 防火墙:关闭 Selinux:关闭 网段:1 ...

随机推荐

  1. Richard Sabey于2004年给出了由123456789各出现一次的e的估计

  2. 小程序 TabBar 定制

    使用微信小程序开发时,用到了其 API - tabBar,设置如下(详细的内容可以参考官网 api): "tabBar": { "color": "# ...

  3. python中的Iterable对象和Iterator

    参考链接:https://www.liaoxuefeng.com/wiki/0014316089557264a6b348958f449949df42a6d3a2e542c000/00143178254 ...

  4. 第一章 Bootstrap简介

    一.Bootstrap简介 Bootstrap是基于 HTML.CSS.JAVASCRIPT 的前端框架,它简洁灵活,使得 Web 开发更加快捷.它由Twitter的设计师Mark Otto和Jaco ...

  5. Ubuntu 终端关机和重启命令

    原文地址:https://blog.csdn.net/zzc15806/article/details/80907779 (diss一下原文地址的作者,你也是转载的为何不添加原文链接?) 重启命令:1 ...

  6. Django-DRF-图书增删改查 !!!

      自己封装的 class MyResponse(): def __init__(self): self.status = 100 self.msg = None @property def get_ ...

  7. django模型层优化(关联对象) 懒加载和预加载 +长链接

    懒加载 存在于外键和多对多关系不检索关联对象的数据调用关联对象会再次查询数据库 问题根源 查看django orm的数据加载,两次. 查询user,查询menu 预加载的方法 预加载单个关联对象--s ...

  8. Java——静态变量/方法与实例变量/方法的区别

    静态只能调用静态 非静态: 对象名.方法名 package ti; //通过两个类 StaticDemo.LX4_1 说明静态变量/方法与实例变量/方法的区别. class StaticDemo { ...

  9. HTML5+CSS3点击指定按钮显示某些内容效果

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  10. 金蝶K3 WISE BOM多级展开_物料齐套表

    /****** Object: StoredProcedure [dbo].[pro_bobang_ICItemQiTao] Script Date: 07/29/2015 16:12:10 **** ...