1分pk10在线注册平台 _

  • 时间:
  • 浏览:0
  • 来源:零度娱乐网_提供酷玩娱乐网技术_羽梦娱乐网资讯

1. 简介

  俗话说:磨刀不误砍柴工,因此在亲戚我们都都要刚结束了了写自动化脚本以后,亲戚我们都都先来学习和了解有几只基本概念,在全版掌握了这有几只概念以后,有有利于亲戚我们都都快速上手,怎么去编写自动化测试脚本。

元素,在你你这些 教程系列,亲戚我们都都说的元素之网页元素(web element)。在网页顶端的文本输入框,按钮,多选,单选,标签,和文字都叫元素,总之,凡是能在页面显示的对象都都不可以 作为页面元素对象。

元素定位,有以后也叫Locator,另另俩个多HTML页面元素,都不可以 用不要 最好的法子去描述你你这些 元素的位置。打个比方,生活中地址,另另俩个多大厦,正常的地址是 xx省xx市xx区xx街道xxx号,你你这些 具体描述以后你你这些 大厦的Locator。同样的道理,另另俩个多网页元素,有的是位置,也都不可以 通

过你这些手段将会表达式去描述你你这些 元素在页面对应的位置。

XPath,XPath即为XML路径语言,它是一种用来选则XML(标准通用标记语言的子集)文档中某帕累托图位置的语言。XPath基于XML的树状组织结构,提供在数据组织结构树中找寻节点的能力,XPath 调快的被开发者采用来当作小型查询语言。

Selenium一共有八种元素定位最好的法子,你你这些 在上一篇文章中将会提到过,其中在实际开发自动化脚本过程中,XPath的使用是最多的、比较好用的一种最好的法子,不要 本文就着重来介绍怎么通过XPath来元素定位。学习了XPath元素定位后,你这些7中最好的法子,很容易理解,甚至

将会法学会了其中好几种最好的法子。

1.1 XPath工具安装

      为了提高抓取元素XPath的,我推荐在Firefox上安装另另俩个多firepath的插件,你你这些 插件,都不可以 帮亲戚我们都都快速获取网页元素的XPath表达式。

1.   打开火狐浏览器,将会没有安装,下载默认安装

2.   点击右上角,菜单-附件组件-扩展

3.   在搜索所有附件组件文本输入框输入:firebug

4.   找到Firebug,点击 安装。重复步骤3和4,搜索和安装FirePath。

5.   安装好了以后,会在火狐浏览器右上角显示另另俩个多虫子的图标。

1.2 XPath工具简单使用

亲戚我们都都用定位百度首页的搜索输入框你你这些 元素定位来演示。

1.   打开百度首页

2.   鼠标定位到搜索输入框

3.   右键鼠标,选Inspect in FirePath

4.   打开界面如下图

①FirePath自动推荐该元素的XPath表达式

②该元素节点的全版信息,XPath表达式选则重点区域

③找到另另俩个多匹配元素

       一般来说,自动推荐的XPath表达式定位过低精确。亲戚我们都都大帕累托图以后不可以 去步骤2中,找出不用可以识别你你这些 唯一元素的节点信息。刚好顶端通过id=kw不可以找到另另俩个多匹配的元素,说明你你这些 XPath可用,看起来也简洁。实际项目中,将会XPath表达式写得很长,将会附

近节点信息好多相同,不太好不用可以快速找到另另俩个多唯一的节点信息去定位你你这些 目标元素。接下来,我介绍几种比较实用的XPath定位技巧,基本都不可以 定位到所有的网页元素。

1.3 XPath定位技巧之text()最好的法子

以百度首页右上角“新闻”定位举例

XPath如下图

1.4 XPath定位技巧之contains()最好的法子

      有以后,亲戚我们都都不喜欢写很长的XPath表达式,因此节点信息顶端,你这些信息是动态的,每次都获取有的是一样,你你这些 以后contains()最好的法子就很好用。

JD首页左侧电脑菜单举例

XPath写法推荐,这里用contains()最好的法子来定位

这里href = //diannao.jd.com, 将会我随便说说你你这些 href太长,我只取关键字diannao,利用contains()最好的法子来定位就方便多了,推荐电脑你你这些 元素的XPath://*/a[contains(@href,'diannao')]

1.5 相对XPath路径写法

      有以后,亲戚我们都都遇到目标元素节点的信息很少,过低够用来精选则位到目标元素,你你这些 以后,亲戚我们都都就不可以 考虑,利用目标元素上下附件节点,通过选则附件的节点从而选则目标元素,你你这些 最好的法子就叫相对路径。

这里用火狐浏览器百度首页的另另俩个多单选按钮来举例;

火狐浏览器上firepath给出的推荐表达式是:

这里推荐的XPath是根据目标元素节点中id信息来定位的,你你这些 通过id就能定位,当然好。有以后,将会你你这些 id不可以作为参考值,亲戚我们都都不可以 利用相对定位最好的法子来定位你你这些 新闻标题前面的单选按钮;

1)先根据value = google_web 将会text()=谷歌来定位“谷歌”你你这些 标签。

2)根据相对定位来选则“谷歌”前面的你你这些 radio按钮。

3)XPath的写法是:.//*/label[@value='google_web']/

此前使用webdriver对浏览器进行了你这些基本操作,都不可以 说是基本接触了你你这些 工具了,接下来就应该做更多事情了。

打开了网页,接下来就不可以 对网页中的内容进行操作了,类似于定位网页中的元素、读取网页元素中的内容、对内容进行操作。

2.小结

XPath 是一种在 XML 文档中定位元素的语言。将会 HTML 都不可以 看做 XML 的一种实现,不要 selenium用户原本使用你你这些 强大语言在 web 应用中定位元素。

2.1 绝对路径定位:

XPath 有多种定位策略,最简单和直观的以后写元素的绝对路径。将会仍然把另另俩个多元素看做另另俩个多人语录,没有现在另另俩个多人,他没有任何属性组织结构,没有你这些个前会占据 于某个地理位置,如:xx 省 xx 市xx 区 xx 路 xx 号。没有对于另另俩个多元素在另另俩个多页面当中也会有

原本的另另俩个多绝对地址。

参考 baidu.html 前端工具所展示的代码,亲戚我们都都都不可以 用下面的最好的法子来找到百度输入框和搜索按钮。

find_element_by_xpath("/html/body/div/div[2]/div/div/div/from/span/input")

find_element_by_xpath("/html/body/div/div[2]/div/div/div/from/span[2]/input")

find_element_by_xpath()最好的法子用于 XPath 语言定位元素。XPath 的绝对路径主要用标签名的层级关系来

定位元素的绝对路径。最外层为 html 语言,body 文本内,一级一级往下查找,将会另另俩个多层级下有多个相同的标签名,没有就按上下顺序选则是第有几只,div[2]表示第八个 div 标签。

2.2 利用元素属性定位:

除了使用绝对路径的以外,XPath 也都不可以 使用使素的属性值来定位。同样以百度输入框和搜索按钮为例:

find_element_by_xpath("//input[@id='kw']")

find_element_by_xpath("//input[@id='su']")

//表示当前页面某个目录下,input 表示定位元素的标签名,[@id='kw'] 表示你你这些 元素的 id 属性值等于kw。下面通过 name 和 class 属性值来定位。

find_element_by_xpath("//input[@id='wd']")

find_element_by_xpath("//input[@class='s_ipt']")

find_element_by_xpath("//*[@class='bg s_btn']")

将会我想要指定标签名也都不可以 用星号(*)代替。当然,使用 XPath 不仅仅只局限在 id、name 和 class 这另另俩个多属性值,元素的任意属性值都都不可以 使用,以后它能唯一的标识另另俩个多元素。

find_element_by_xpath("//input[@maxlength='3000']")

find_element_by_xpath("//input[@autocomplete='off']")

find_element_by_xpath("//input[@type='submit']")

2.3 层级与属性结合:

将会另另俩个多元素一种并没有都不可以 唯一标识你你这些 元素的属性值,亲戚我们都都都不可以 找其上一级元素,将会它的上级

有都不可以 唯一标识属性的值,也都不可以 拿来使用。参考 baidu.html 文本。

……

<form id="form" class="fm" action="/s" name="f">

<input type="hidden" value="utf-8" name="ie">

<input type="hidden" value="8" name="f">

<input type="hidden" value="1" name="rsv_bp">

<input type="hidden" value="1" name="rsv_idx">

<input type="hidden" value="" name="ch">

<input type="hidden" value="02.." name="tn">

<input type="hidden" value="" name="bar">

<span class="bg s_ipt_wr">

<input id="kw" class="s_ipt" autocomplete="off"

maxlength="3000" value="" name="wd">

</span>

<span class="bg s_btn_wr">

<input id="su" class="bg s_btn" type="submit"

value="百度一下">

</span>

……

以后百度输入框一种没有可利用的属性值,亲戚我们都都都不可以 查找它的上一级属性。比如,“小明”刚出生的以后没有名字,没上户口(没身份证号),没有亲朋好友来找“小明”都不可以 先到小明的爸爸,将会他爸爸是有不要 属性组织结构的,找到了小明的爸爸,抱在怀里的一定以后小

明了。通过 XPath 描述如下:

find_element_by_xpath("//span[@class='bg s_ipt_wr']/input")

find_element_by_xpath("//span[@class='bg s_btn_wr']/input")

span[@class='bg s_ipt_wr'] 通过 class 属性定位到是父元素,顶端/input 也就表示父元素下面标签名为input 的子元素。将会父元素没有可利用的属性值,没有都不可以 继续向上查找“爷爷”元素。

find_element_by_xpath("//form[@id='form']/span/input")

find_element_by_xpath("//form[@id='form']/span[2]/input")

亲戚我们都都都不可以 通过你你这些 最好的法子一级一级的向上打找,直到找到最外层的<html>标签,没有以后另另俩个多绝对路径的写法了。

2.4 使用逻辑运算符

将会另另俩个多属性不可以唯一的区分另另俩个多元素,亲戚我们都都还都不可以 使用逻辑运算符连接多个属性来区别于其它属性。

……

<input id="kw" class="su" name="ie">

<input id="kw" class="aa" name="ie">

<input id="bb" class="su" name="ie">

……

如顶端的三行元素,以后亲戚我们都都现在要定位第一行元素,将会使用 id 将会与第二行元素重名,将会使用class 将会与第三行元素的重名。没有将会一块儿使用 id 和 class 就会唯一的标识你你这些 元素。没有你你这些 以后就都不可以 通过逻辑运算符号连接。

find_element_by_xpath("//input[@id='kw' and @class='su']/span/input")

当然,亲戚我们都都也都不可以 用 and 连接更多的属性来唯一的标识另另俩个多元素。

亲戚我们都都在本书的第一章中介绍的 Firebug 前端调试工具和 FirePath 插件都不可以 方便的辅助 XPath 语法。

打开 FireFox 浏览器的 FireBug 插件,点击插件左上角的鼠标箭头,再点击页面上不可以 定位的元素,在元

素行上右键弹出快捷菜单,选则“克隆 XPath”,将会获得当前元素的 XPath 语法,如图:

FirePath插件的使用就更加方便和快捷了,选中元素后,直接在XPath的输入框中生成当前元素的XPath语法,如图:

您的肯定以后我进步的动力。将会你感觉还不错,就请鼓励一下吧!记得点波 推荐 暂且忘记哦!!!