元素定位的方法有2个

driver.findElement(By.args) 返回值是WebElement            //此方法是获取单一的页面元素

driver.findElements(By.args) 返回值是list<WebElement>  //此方法是获取多个页面元素;例如:获取一组复选框,然后都打上√号

两种方法获取页面元素方法基本一样

<input id="kw" name="wd" class="s_ipt" value="" maxlength="255" autocomplete="off">

1、通过id进行定位--By.id()

driver.findElement(By.id("kw")).click();

2、通过name进行定位--By.name()

driver.findElement(By.name("wd")).click();

3、通过clasName进行定位--By.className()

driver.findElement(By.className("s_ipt")).sendKeys("通过class属性进行定位");

4、通过标签名字进行定位--By.tagName()

driver.findElements(By.tagName("input"));

5、通过linktext(超链接)进行定位--By.linkText()

<a href="https://www.hao123.com" name="tj_trhao123" class="mnav">hao123</a>

driver.findElement(By.linkText("hao123")).click();      //此方法是根据超链接的所有文字进行定位

driver.findElement(By.partialLinkText("hao")).click();  //此方法是根据超链接的部分文字进行定位

6、通过css选择器进行定位--By.cssSelector()

driver.findElement(By.cssSelector("#kw")).sendKeys("通过css id选择器进行定位");          //通过id属性进行定位

driver.findElement(By.cssSelector(".s_ipt")).sendKeys("通过css class选择器进行定位");   //通过class 属性进行定位

driver.findElement(By.cssSelector("input")).sendKeys("通过标签名进行定位");                 //通过标签名进行定位

driver.findElement(By.cssSelector("input")).sendKeys("通过标签名进行定位");                 //通过标签名进行定位

driver.findElement(By.cssSelector("input[maxlength='250']")).sendKeys("通过标签属性值进行定位");                 //通过标签属性值进行定位

7、通过xpath进行定位--By.xpath()

这个方法是非常强大的元素查找方式,使用这种方法几乎可以定位到页面上的任意元素。

优点:基本上是万能的

缺点:因为要遍历所愿元素的路径,执行效率可能比较慢

定位的方法有两种:

“/” 绝对路径,从页面的根元素开始

“//” 相对路径,从页面上的任何节点开始匹配

driver.findElement(By.xpath("//input[@id='kw']")).sendKeys("通过xpath进行定位");   //查找页面上id=kw的input输入框

driver.findElement(By.xpath("//form[1]/input"))      //查找页面上第一个form元素内的直接子input元素(即只包括form元素的下一级input元素,使用绝对路径表示,单/号)

driver.findElement(By.xpath("//form[1]//input"))      //查找页面上第一个form元素内的所有子input元素(只要在form元素内的input都算,不管还嵌套了多少个其他标签,使用相对路径表示,双//号)

 xpath作为定位神器也可以进行模糊匹配

contains(@alt,'value');  //@alt 表示某个标签上的属性名,value表示属性的值

driver.findElement(By.xpath("//a[contains(@title,'我评论过的博文')]")).click();   //查找页面上包含 属性 title=‘我评论过的博文’ <a />标签,@后面的title 可以替换成元素的任意其他属性

[starts-with(@alt, ‘value’)   // 以属性值=value开头的元素

driver.findElement(By.xpath(“//a[starts-with(@rel, ‘nofo’)]));     //查找页面上 rel属性以nofo开头的a元素。其中@后面的rel可以替换成元素的任意其他属性。

 总结:

页面上有id属性时,尽量用id

定位超级链接时可以考虑用 linktext

可以用xpath定位不好定位的元素,但是性能比较差

可以用tagName 定位同一组元素

selenium 元素定位常用的方法的更多相关文章

  1. python+selenium元素定位——8种方法

    定位元素,selenium提供了8中元素定位方法: (1)find_element_by_id() :html规定,id在html中必须是唯一的,有点类似于身份证号 (2)find_element_b ...

  2. Selenium3 + Python3自动化测试系列二——selenium元素定位

    一.selenium元素定位 Selenium对网页的控制是基于各种前端元素的,在使用过程中,对于元素的定位是基础,只有准去抓取到对应元素 才能进行后续的自动化控制,我在这里将对selenium8种元 ...

  3. selenium元素定位之css选择器

    在selenium元素定位时会用到css选择器选取元素,虽说xpath在定位元素时能解决大部分问题,但使用css选择器选取元素也是一种不错的选择. css相较与xpath选择元素优点如下: 表达式更加 ...

  4. selenium元素定位陷阱规避

    为什么selenium可以在各个浏览器上运行?因为selenium在与各个浏览器驱动执行前,会先把脚本转化成webdriver, webdriver wire协议(一种json格式的协议),这样就与脚 ...

  5. 自动化测试基础篇--Selenium元素定位

    摘自https://www.cnblogs.com/sanzangTst/p/7457111.html 一.Selenium元素定位的重要性: Web自动化测试的操作:获取UI页面的元素,对元素进行操 ...

  6. selenium元素定位方法

    一.如何找到页面元素 Webdriver的findElement方法可以用来找到页面的某个元素,最常用的方法是用id和name查找.下面介绍几种比较常用的方法. 1.1By ID 假设页面写成这样:i ...

  7. python之selenium元素定位方法

    前提: 大家好,今天我们来学习一下selenium,今天主要讲解selenium定位元素的方法,希望对大家有所帮助! 内容: 一,selenium定位元素 selenium提供了8种方法: 1.id ...

  8. selenium元素定位大全

    要做自动化,首先要了解页面结构,要了解页面结构,就要了解页面元素的定位方法 在使用selenium webdriver进行元素定位时,通常使用findElement或findElements方法结合B ...

  9. selenium元素定位

    在网页自动化测试中,我们要让程序自动模拟我们的点击.输入.悬浮.拖动等操作,完成我们的测试用例组. 输入.点击.打开这样的动词,已经包含在了selenium的方法中,可以直接调用(当然你也可以自己写) ...

随机推荐

  1. [算法总结] 动态规划 (Dynamic Programming)

    本文组织结构如下: 前言 最长公共子序列(LCS) 最长不下降子序列(LIS) 最大连续子序列之和 最长回文子串 数塔问题 背包问题(Knapsack-Problem) 矩阵链相乘 总结 前言 在学过 ...

  2. 给 EF Core 查询增加 With NoLock

    给 EF Core 查询增加 With NoLock Intro EF Core 在 3.x 版本中增加了 Interceptor,使得我们可以在发生低级别数据库操作时作为 EF Core 正常运行的 ...

  3. Java 学习笔记 第一章:Java语言开发环境搭建

    第一章:Java语言开发环境搭建 第二章:常量.变量和数据类型 第三章:数据类型转换.运算符和方法入门 1.Java虚拟机——JVM JVM(Java Virtual Machine ):Java虚拟 ...

  4. Functor、Applicative 和 Monad

    Functor.Applicative 和 Monad 是函数式编程语言中三个非常重要的概念,尤其是 Monad. 说明:本文中的主要代码为 Haskell 语言,它是一门纯函数式的编程语言. 一.结 ...

  5. [codeforces]Page Numbers <模拟>

    描述: «Bersoft» company is working on a new version of its most popular text editor — Bord 2010. Bord, ...

  6. 相见恨晚的 Git 命令动画演示,一看就懂!

    虽然 Git 是一个强大的工具,但是我觉得大部分人都会同意我说的:它也可以是一个--噩梦!我一直觉得,使用 Git 的时候把操作过程在脑海里视觉化会非常有用:当我执行某个命令的时候,分支之间是如何交互 ...

  7. php源码的编译

    本片文章主要介绍windows下的php源码的编译. 1.1 编译环境 软件 环境 操作系统 Windows 7 专业版 32bit Visual studio 2012 专业版 PHP 5.5.2. ...

  8. SWUSTOJ 509B 恶心了几个月想不通的low题

    SWUSTOJ 509B 这个题恶心了我好久,细细算来不难,算总天数,减去星期一,与4取余, 问题在最后除掉多余的星期一,按照上述算法,在最后一个星期会出现过了星期一但不足7天,程序未能减去多余的星期 ...

  9. PTA数据结构与算法题目集(中文) 7-28

    PTA数据结构与算法题目集(中文)  7-28 7-28 搜索树判断 (25 分)   对于二叉搜索树,我们规定任一结点的左子树仅包含严格小于该结点的键值,而其右子树包含大于或等于该结点的键值.如果我 ...

  10. django自定义实现登录验证-更新版

    django自定义实现登录验证 django内置的登录验证必须让开发者使用django内置的User模块,这会让开发者再某些方面被限制住 下面的模块是我自己自定义实现的django验证,使用方式和dj ...