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. Git Gerrit使用

    Git Gerrit 操作都用 git bash操作: 如果想用 cmd 或者 PowerShell,系统环境变量 Path 添加 Git 安装路径,如: C:\Program Files (x86) ...

  2. python:函数和循环判断

    输出显示 先说一下最基础的输出: print('hello world') 唯一值得提到是字符串的format函数. format函数代替了C中的%s. print('{0} say:{0} {1}. ...

  3. Web应用程序的敏感信息-隐藏目录和文件

    Web应用程序的敏感信息-隐藏目录和文件 0x1.场景 Web应用程序根文件夹中可能存在大量隐藏信息:源代码版本系统文件夹和文件(.git,.gitignore,.svn),项目配置文件(.npmrc ...

  4. Python Day2 (二)

    字典的操作: 见连接: http://www.cnblogs.com/alex3714/articles/5717620.html 第二天作业,修改haproxy配置文件. 程序练习 程序1: 实现简 ...

  5. js中子页面父页面方法 变量相互调用(转)

    原文:https://www.cnblogs.com/huangshuqiang/p/5734358.html (1)子页面调用父页面的方法或者变量: window.parent.方法()或者变量名w ...

  6. jenkins结合gitlab实现提交代码自动构建

    jenkins可以说是现在非常流行的一个继续集成工具,几乎所有的公司都在用,并且它也基本是devops的连接者,是一个比较核心的工具. 主要记录以下两个: 利用jenkins和gitlab的webho ...

  7. 51nod--1006 最长公共子序列Lcs (动态规划)

    题目: 给出两个字符串A B,求A与B的最长公共子序列(子序列不要求是连续的). 比如两个串为: abcicba abdkscab ab是两个串的子序列,abc也是,abca也是,其中abca是这两个 ...

  8. es2015 解构赋值

    解构赋值语法是一个 Javascript 表达式,这使得可以将值从数组或属性从对象提取到不同的变量中.

  9. php 两变量值互换 方法

    //方法一:$a ="abc";$b="def"; $a = $a^$b;$b = $b^$a;$a = $a^$b; //方法二:list($a, $b)= ...

  10. 初学python之路-day02

    python,诞生于1989年的圣诞,Guido van Rossum为了打发无聊,因此发明了python,并且开放了其源代码,使得这门语言在随后的几十年的发展的越来越广.现今,2.x版本已经在2.7 ...