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. C++创建对象的三种方法

    我自己以前经常弄混 A a(1); 栈内存中分配 A b = A(1); 栈内存中分配,和第一种无本质区别 A c = new A(1); 堆内存中分配 前两种在函数体执行完毕之后会被释放,第三种需要 ...

  2. a标签跳页传参,以及截取URL参数

    <a href="dd.index?aa=1&&bb=2"></a> //截取URL参数 // console.log(window.loc ...

  3. gitlab服务器搭建

    当然喜欢英文的可以参考官方文档:https://about.gitlab.com/downloads/ 1.  根据自己的操作系统选择相应的安装方法,我这边是阿里云 centos 7的 sudo yu ...

  4. 【转】mac环境下Android 反编译

    一.需要的工具 apktool:反编译APK文件,得到classes.dex文件,同时也能获取到资源文件以及布局文件. dex2jar:将反编译后的classes.dex文件转化为.jar文件. jd ...

  5. DataStructure-链表实现指数非递减一元多项式的求和

    // 2-链表实现多项式的求和.cpp : 定义控制台应用程序的入口点. // #include "stdafx.h" #include<stdio.h> #inclu ...

  6. English 动词篇

    动词后加to do 和 doing的记忆口诀 一.只能用动名词(ing)作宾语 [口诀] 考虑建议盼原谅,承认推迟没得想. 避免错过继续练,否定完成停欣赏. 禁止想象才冒险,不禁介意弃逃亡. cons ...

  7. Python 通用爬虫 和讯博客 scrapy

    目标站点需求分析 通用爬虫,获取和讯博客所有博文 涉及的库 scrapy,re,requests,mysql URL RULE 解析单页源码 保存到数据库 结果

  8. Monkey自动化脚本(一)

    1.Monkey简介 Monkey-猴子,通过Monkey程序模拟用户触摸屏幕.滑动Trackball. 按键等操作来对设备上的程序进行压力测试,检测程序多久的时间会发生异常,主要用于Android ...

  9. 【python3 自动化基础之pip】pip常用命令归类

    1.升级pippython -m pip install --upgrade pip(包名) 2.安装pymysql pip install pymysql 3.pip按照到指定目录 python - ...

  10. 【web】服务器推送的实现方式(转)

    轮询 http流 websocket   https://www.cnblogs.com/freud/p/8397934.html http2.0 浅谈Websocket.Ajax轮询和长连接(lon ...