在网页自动化测试中,我们要让程序自动模拟我们的点击、输入、悬浮、拖动等操作,完成我们的测试用例组。

输入、点击、打开这样的动词,已经包含在了selenium的方法中,可以直接调用(当然你也可以自己写),

但如何让这些动作精准的作用到我们想要作用的对象上呢?

这就要用到“元素定位”!!!

说了这么多,终于进入正题了。

以百度的首页为例,定位以下三个元素

先来看一些这些元素的html代码

输入框

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

搜图按键

<span class="soutu-btn"></span>

新闻

<a class="mnav" href="http://news.baidu.com" name="tj_trnews">新闻</a>

hao123

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

定位的方法有很多种,小编先介绍一些基础的,常用的。在页面中找到某一元素的方法式find_element_by_XXX()。

前驱代码:

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

定位元素的方式有很多种,这里小编仅简单的介绍常用的5种方法。

1.通过id定位到“百度一下”,并输入字符串“selenium”

driver.find_element_by_id(“kw”).send_keys("selenium")

备注一下,send_keys()方法是向文本框中输入字符使用的。

2.通过calss name定位到搜图按键

driver.find_element_by_class_name(“soutu-btn”).click()

class可以将样式一致的内容封装在一起,给同一种CSS样式。像搜图按键,在整个页面上也没有兄弟姐妹,因此它的class是它自己独享的,

而像是“新闻”这一排内容,一个css里面有一堆元素,又该如何定位呢?

<div id="u1">
<a class="mnav" href="http://news.baidu.com" name="tj_trnews">新闻</a>
<a class="mnav" href="http://www.hao123.com" name="tj_trhao123">hao123</a>
<a class="mnav" href="http://map.baidu.com" name="tj_trmap">地图</a>
<a class="mnav" href="http://v.baidu.com" name="tj_trvideo">视频</a>
<a class="mnav" href="http://tieba.baidu.com" name="tj_trtieba">贴吧</a>
<a class="mnav" href="http://xueshu.baidu.com" name="tj_trxueshu">学术</a>
</div>

按照刚刚的,来试一下

driver.find_element_by_class_name("mnav").click()

结果,居然是进入了“新闻”页,打开了第一个的连接,这可怎么办呢?对于这种固定的超链接,好解决,可以选择使用其他定位方式.

3.通过css selector

css是样式表,定义了元素的显示方式。

推荐w3cSchool的css课程:http://www.w3school.com.cn/css3/index.asp

css一般用“.”来代表class属性;用"#"来代表id属性;各种标签,就直接以标签的名字(如input)来表示。

例:在百度的搜索框内输入:selenium

 回顾一下百度搜索框的代码

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

通过css来定位的方法为find_element_by_css_selector("")

前驱代码

#在百度首页输入selenium
driver.get("http://www.baidu.com")
time.sleep(3)

通过css属性定位

#通过id属性
driver.find_element_by_css_selector("#kw").send_keys("selenium")
#通过class属性
driver.find_element_by_css_selector(".s_ipt").send_keys("selenium")
#通过标签
driver.find_element_by_css_selector("input").send_keys("selenium")

注:上述三种方法,在验证其中一种时,请将另外两种注释掉。

单行注释可以在注释内容前加#,如上代码

多行注释,可以使用三对引号。

'''
三对
单引号
的注释
'''
driver.get("http://e.firefoxchina.cn/")
"""
三对
双引号
的注释
"""

对于复杂的html,一个属性或许无法定位,但是可以使用属性的叠加,达到用css定位的目的。

T[attribute='value'] 查找指定标签T下,含有attribute属性,且属性值为value的元素
T[attribute^='value'] 查找指定标签T下,含有attribute属性,且属性值以value开头的元素
T[attribute$='value'] 查找指定标签T下,含有attribute属性,且属性值以value结尾的元素
T[attribute*='value'] 查找指定标签T下,含有attribute属性,且属性值包含value的元素

例:点击百度首页的“hao123”

<div id="u1">
<a class="mnav" href="http://news.baidu.com" name="tj_trnews">新闻</a>
<a class="mnav" href="http://www.hao123.com" name="tj_trhao123">hao123</a>
``````
</div>

我们可以使用css selector,通过name的属性的确定。

driver.find_element_by_css_selector("a[name='tj_trhao123']").click()

4.通过link text定位超链接

link是专门对超链接进行操作的,它的对象是我们可以看得到的超链接文字,有精准匹配和模糊匹配两种形式:

  • 精准匹配-打开hao 123
driver.find_element_by_link_text("hao123").click()
  • 模糊匹配-打开hao123

driver.find_element_by_partial_link_text("123").click()

5.通过XPath

什么是XPath?

XPath是XML路径语言,通俗来讲,是一种根据html的标签的嵌套,来确定网页中某元素位置的语言。

但仍有一个问题,有些浏览器不支持xpath解析,而不同的浏览器对网页源代码的解析也有可能不一致,所以很多时候需要我们针对不同的浏览器,做一定的改动。

XPath手动编写的操作,这里不做介绍,小编直接讲一讲如何用火狐浏览器的插件Firepath来获取XPath。

  • 在火狐浏览器中装插件:

  

在“扩展页签”里搜索FirePath,搜索

在其他可用附加组件中,找到FirePath,安装之后浏览器会提示重启浏览器。

重启之后,按F12,进入开发者模式,就会看到,多了FirePath的页签。选中一个元素进行查看时,XPath处会自动判断出它的XPath值。

例如,我找到的是火狐首页中的“新浪”超链接,现在我们将它自动打开。

from selenium import webdriver
import time driver=webdriver.Firefox()
driver.get("http://e.firefoxchina.cn/")
time.sleep(2)
driver.find_element_by_xpath(".//*[@id='site-my-list']/ul/li[2]/a").click()

结果,当然就是成功的打开啦。

selenium元素定位的更多相关文章

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

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

  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元素定位篇

    Selenium webdriver是完全模拟用户在对浏览器进行操作,所有用户都是在页面进行的单击.双击.输入.滚动等操作,而webdriver也是一样,所以需要我们指定元素让webdriver进行单 ...

  6. python学习之——selenium元素定位

    web自动化测试按步骤拆分,可以分为四步操作:定位元素,操作元素,获取返回结果,断言(返回结果与期望结果是否一致),最后自动出测试报告. 其中定位元素尤为关键,此篇是使用webdriver通过页面各个 ...

  7. python selenium 元素定位(三)

    上两篇的博文中介绍了python selenium的环境搭建和编写的第一个自动化测试脚本,从第二篇的例子中看出来再做UI级别的自动化测试的时候,有一个至关重要的因素,那就是元素的定位,只有从页面上找到 ...

  8. selenium元素定位大全

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

  9. selenium元素定位不到之iframe

    我们在使用selenium的18中定位方式的时候,有时会遇到定位不上的问题,今天我们就来说说导致定位不上的其中一个原因---iframe 问题描述:通过firebug查询到相应元素的id或name等, ...

随机推荐

  1. python邮件SMTP的GUI编程

    写的是python中smtp的gui编程,用的163邮箱给qq邮箱发送邮件做测试,如果你发现你的发送失败,试着用以下方法解决: 1.网页登陆你的邮箱,设置中查看smtp是否开启,比如163邮箱的smt ...

  2. 用python爬虫爬取去哪儿4500个热门景点,看看国庆不能去哪儿

    前言:本文建议有一定Python基础和前端(html,js)基础的盆友阅读. 金秋九月,丹桂飘香,在这秋高气爽,阳光灿烂的收获季节里,我们送走了一个个暑假余额耗尽哭着走向校园的孩籽们,又即将迎来一年一 ...

  3. sqlserver 缩小表空间

    1. 保留需要的数据之新表中->TRUNCATE原表数据->还原之前保留的数据之原表中->压缩表空间 脚本类似如下 SELECT * INTO #keep FROM Original ...

  4. topN 算法 以及 逆算法(随笔)

    topN 算法 以及 逆算法(随笔) 注解:所谓的 topN 算法指的是 在 海量的数据中进行排序从而活动 前 N 的数据. 这就是所谓的 topN 算法.当然你可以说我就 sort 一下 排序完了直 ...

  5. 反射型 DDoS 攻击的原理和防范措施

    随着僵尸网络的兴起,同时由于攻击方法简单.影响较大.难以追查等特点,分布式拒绝服务攻击(DDoS,Distributed Denial of Service)得到快速壮大和日益泛滥. 成千上万主机组成 ...

  6. 如何在 UWP 使用 wpf 的 Trigger

    本文需要告诉大家,如何使用 Behaviors 做出 WPF 的 Trigger ,需要知道 UWP 不支持 WPF 的 Trigger . 安装 Behaviors 请使用 Nuget 安装,可以输 ...

  7. Anroid四大组件service之本地服务

    服务是Android四大组件之一,与Activity一样,代表可执行程序.但Service不像Activity有可操作的用户界面,它是一直在后台运行.用通俗易懂点的话来说: 如果某个应用要在运行时向用 ...

  8. Linux: 查看软件安装路径

    一.        Which 命令 Shell 的which 命令可以找出相关命令是否已经在搜索路径中. 如: [root@localhost ~]# which gcc /usr/bin/gcc ...

  9. Windows下安装RabbitMQ

    今天正好给自己机器安装rabbitmq,总结下安装经验. 现在国内访问erlang,和 RabbitMQ 官网好像都很难连上.我已下载好了资源,需要的朋友可以下载. 链接: https://pan.b ...

  10. Windows中 MySQL5.7.17解压版安装步骤

    1.先去MySQL官网下载.当前最新版是5.7.19,可能安装方法不同了,本人测试没有安装成功,若有安装成功的朋友,希望分享一下安装步骤. 个人推荐下载MySQL5.7.17,官方下载网址:https ...