在使用selenium webdriver进行元素定位时,有8种基本元素定位方法(注意:并非只有8种,总共来说,有16种)。

   分别介绍如下:

1.name定位

(注意:必须确保name属性值在当前html页面中是唯一的)

    页面源码如下:

        "<button name="btnK">Google Search</button>"

    当我们要用name属性来定位这个按钮元素并点击它时,代码如下:

        driver.find_element_by_name('btnK').click()

2.id定位

(注意:必须确保id属性值在当前html页面中是唯一的)

    页面源码如下:

        "<button id="gbqfba">Google Search</button>"

    当我们要用id属性来定位这个按钮元素并点击它时,代码如下:

        driver.find_element_by_id('gbqfba').click()

3.tagNamed定位

(注意:必须确保标签在当前html页面中是唯一的,标签名在html页面中一般不唯一,所以定位单个元素时很少用,定位一组元素时用)

    页面源码如下:

        "<button>Google Search</button>"

    当我们要用tagName属性来定位这个按钮元素并点击它时,代码如下:

        driver.find_element_by_tag_name('button').click()

4.className定位

    (注意:必须确保className属性值在当前html页面中是唯一的)

    一:class属性值只有一个

        页面源码如下:

            "<button class="gbqfba">Google Search</button>"

        当我们要用className属性来定位这个按钮元素并点击它时,代码如下:

            driver.find_element_by_class_name('gbqfba').click()

    二:class属性值存在多个

    注意:使用className来进行元素定位时,有时会碰到一个元素指定了若干个class属性值的“复合样式”的情况

    页面源码如下:

        <button class ="btn btn_big btn_submit">登录</button>

    这个元素的class有三个不同的值,我们只需要选择其中一个值就好了,代码如下:

        driver.find_element_by_class_name('btn_submit').click()

5.linkText定位

    页面源码如下:

        <a href="/intl/en/about.html">我的名字叫做Kevin</a>

    当我们要用linkText属性来定位这个按钮元素并点击它时,代码如下:

        driver.find_element_by_link_text('我的名字叫做Kevin').click()

6.partialLinkText定位

(注意:这个方法是上一个方法的扩展。当你不能准确知道超链接上的文本信息或者只想通过一些关键字进行匹配时,可以使用这个方法来通过部分链接文字进行匹配。)

    页面源码如下:

        <a href="/intl/en/about.html">我的名字叫做Kevin</a>

    当我们要用linkText属性来定位这个按钮元素并点击它时,代码如下:

        driver.find_element_by_partial_link_text('Kevin').click()

7.xpath定位

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

查找页面根元素: //

查找页面上所有的input标签的元素: //input

    代码:driver.find_elements_by_xpath('//input[1]')  #注意:加个s代表定位多个元素

查找页面上第一个input标签的元素: //input[1]

    代码:driver.find_element_by_xpath('//input[1]')

查找页面上标签为form且id为loginForm元素: //form[@id="loginForm"]

    代码:driver.find_element_by_xpath('//form[@id="loginForm"]')

查找页面上具有name属性为username的input标签的元素: //input[@name="username"]

    代码:driver.find_element_by_xpath('//input[@name="username"]')

查找页面上id为loginForm的form元素下的第一个input元素: //form[@id="loginForm"]/input[1]

    代码:driver.find_element_by_xpath('//form[@id="loginForm"]/input[1]')

查找页面具有name属性为contiune并且type属性为button的input元素: //input[@name="continue" and @type="button"]

    代码:driver.find_element_by_xpath('///input[@name="continue" and @type="button"]')

查找页面上id为loginForm的form元素下第4个input元素: //form[@id="loginForm"]/input[4]

    代码:driver.find_element_by_xpath('//form[@id="loginForm"]/input[4]')

前面讲的都是xpath中基于准确元素属性的定位,其实xpath作为定位神器也可以用于模糊匹配。

    1.用contains关键字,定位代码如下:

    driver.find_element_by_xpath("//a[contains(@href,‘logout’)]")

    2.用start-with关键字,定位代码如下:

    driver.find_element_by_xpath("//a[starts-with(@rel,"nofo")]");

    3.用Text关键字,定位代码如下:

    driver.find_element_by_xpath('//*[text()="退出"]');  4.用ends-with关键字,定位代码如下

 driver.find_element_by_xpath("//a[ends-with(@rel,"nofo")]");

8.css定位

css定位元素方式跟xpath比较类似,但执行速度较快,而且各种浏览器对它的支持都相当到位,所以功能也是蛮强大的。

下面是一些常见的cssSelector的定位方式:

定位id为flrs的div元素可以写成:#flrs     注:相当于xpath语法的//div[@id=’flrs’]

定位id为flrs下的a元素,可以写成 #flrs>a  注:相当于xpath语法的//div[@id=’flrs’]/a

定位id为flrs下的href属性值为 /forexample/about.html的元素,可以写成: # flrs > a[href=”/forexample/about.html”]

如果需要指定多个属性值时,可以逐一加在后面,如  #flrs>input[name=”username”][type=”text”]

最后再总结一下,各种方式在选择的时候应该怎么选择:

1.当页面元素有id属性时,尽量用id来定位。

2.xpath是屠龙刀,css是倚天剑,双剑合璧,才可以天下无敌,所以最好把这两种定位方式都掌握。

3.很多人说xpath定位比css慢,但个人感觉速度上没什么区别,可能是0.01和0.1的区别吧。

selenium自动化之元素定位方法的更多相关文章

  1. Selenium之WebDriver元素定位方法

    Selenium WebDriver 只是 Python 的一个第三方框架, 和 Djangoweb 开发框架属于一个性质. webdriver 提供了八种元素定位方法,python语言中也有对应的方 ...

  2. 关于UI自动化IOS元素定位方法说明

    1. 元素属性介绍 下图是通过weditor定位的微博的"我的钱包",各属性如下图: className:元素类型,如:XCUIElementTypeButton isEnable ...

  3. Selenium 八种元素定位方法

    前言: 我们在做WEB自动化时,最根本的就是操作页面上的元素,首先我们要能找到这些元素,然后才能操作这些元素.工具或代码无法像我们测试人员一样用肉眼来分辨页面上的元素.那么我们怎么来定位他们呢? 在学 ...

  4. Selenium八种元素定位方法源码阅读

    接触过Selenium的都知道元素定位有八种方法,但用不同的方法在执行时有什么区别呢? 元素定位8种方法(Python版),当然还有每一个方法对应的find_elements方法 find_eleme ...

  5. Selenium自动化-CSS元素定位

    接下来,开始讲解 CSS元素定位. CSS定位速度快,功能多,但是不能向上查找,比 xpath好用,是本人认为最好用的定位方式   大致用法总结: 具体使用仿上篇博客.http://www.cnblo ...

  6. selenium常见的元素定位方法

    一.获取元素 1)通过谷歌浏览器自动的工具访问百度首页,我们可以看到,页面上的元素都是由一行行的代码组成的,它们之间有层级地组织起来,每个元素之间都有不同的标签和值,我们可以通过这些不同的标签和值来找 ...

  7. Selenium自动化测试之元素定位

    步骤: 1.通过前端工具,查看元素的属性 2.通过属性定位 iddriver.findElement(By.id("kw")) namedriver.findElement(By. ...

  8. selenium+python自动化之元素定位

    自动化按步骤拆分的话,可以分为四步操作:定位元素,操作元素,获取返回结果,断言(返回结果与期望结果是否一致),最后自动出测试报告.本篇接下来讲基本的八种元素定位方法.说的通俗一点,就是教大家找对象. ...

  9. Selenium Web元素定位方法

    Selenium是用于Web应用测试的自动化测试框架,可以实现跨浏览器和跨平台的Web自动化测试.Selenium通过使用WebDriver API来控制web浏览器,每个浏览器都都有一个特定的Web ...

随机推荐

  1. ethereumjs/browser-builds

    https://github.com/ethereumjs/browser-builds ethereumjs - Browser Builds This repository contains br ...

  2. saltstack安装配置(yum)

    主机规划: (主)master:192.168.25.130 (从)minion:192.168.25.131     192.168.25.132 1.yum安装: 服务端:安装master yum ...

  3. 链表推导式 【list comprehension】

    x for x in x 链表推导式 [list comprehension]链表推导式提供了一个创建链表的简单途径,无需使用 map(), filter() 以及 lambda.返回链表的定义通常要 ...

  4. AMQ(approximate membership queries)介绍

    目录 简介 举例 Bloom Filter 算法过程 1)位数组: 2)添加元素,k个独立hash函数 3)判断元素是否存在集合 Quotient Filter and Cascade Filter ...

  5. 深度包检测(DPI)详细介绍

    目录 简介 背景 流量识别 常用功能 具体功能 做法 特征识别 架构举例 部署方式 串接方式 并接方式 存在问题 检测引擎举例 参考文献 简介 DPI(Deep Packet Inspection)深 ...

  6. Oracle 实例管理

    理解初始化参数文件实例由内存中构建它的参数来定义.许多参数(但不是全部)可以在启动后更改.有些参数在启动时就固定了,只能在关闭实例并再次启动时更改. 静态和动态参数文件参数文件由两类:静态参数文件(也 ...

  7. LR--用栈实现移进--归约分析(demo)

    1.考虑文法 \(E->E+E\) \(E->E*E\) \(E->id\) 2.最右推导 不难看出,这个文法是而二义的,所以有多个最右推导 3.移进归约 用一个栈存文法符号,用输入 ...

  8. 追溯了解Ubuntu之------基本命令操作(叁)

    在使用Ubuntu中的一些基本命令与Linux中是有区别的: 1.       查看Ubuntu系统位数:uname  -ar 或 getconf LONG_BIT 2.          获取Ubu ...

  9. echarts踩坑---容器高度自适应

    在echarts中,若设置固定高度,当柱状图数据过多时会出现数据相互挤压,给用户的体验十分糟糕,可以通过给容器设置自适应高度,然后通过getDom()的方法解决此问题. 具体解决办法如下: <d ...

  10. JS参考手册

    一.JavaScript Core API 词法结构 字符集 使用Unicode字符集 注释 单行注释 //或HTML风格的<!-- 多行注释 /**/ 标识符 大小写 区分大小写 空格.换行. ...