Selenium Selenium:xPath 定位实践

使用过selenium的朋友相信都了解selenium给用户提供了几种不同的元素定位方式。

今天在这里我们不讨论几种定位方式的优劣,只针对性的讨论xpath的使用方法与一些技巧。本人一直是坚定的xpath党,定位方式非常灵活,而且运用熟练了之后,还可以对UI自动化的PO模式进行扩展。

绝对路径vs相对路径

相对其他定位方式来说,xpath的使用有一定的门槛,刚开始接触时可能只会通过浏览器的定位元素功能直接复制xpath绝对路径,比如这样的

/*[@id="root"]/section/div[1]/div/div/div/form/section[1]/div[2]/ul/li[1]/button

这样的绝对路径xpath至少存在两个方面的问题

1、可读性和可维护性很差,这一长串路径看得人眼睛都花,别说维护了。

2、健壮性差,现在的前端框架很多元素都是根据实际业务动态生成的,而页面元素结构稍微变化,继续使用绝对路径就可能会定位不到元素了。

所以说,想要使用xpath进行定位,使用绝对路径是肯定不行的。而是用相对路径就要求我们必须对xpath有一定的了解,xpath的几个关键知识离不开以下两个方面

1、xpath提供的各种函数

2、xpath轴

我们再来分析一下上面这个button元素

首先它是在一个id为root的div容器里中一个form表单的子元素

button的子元素是一个innerText为 【查 询】的span

我们可以把上面的xpath改造一下

//div[@id='root']//span[text()='查 询']/..

然后按F12打开Chrome浏览器的控制台,切换到elements标签,按Ctrl+F激活查询对话框,将xpath输入到搜索框中,可以看到浏览器定位到了这个button元素

这样我们就通过xpath的相对定位定位到了这个button元素,并且忽略掉了DOM树中大部分中间层级

可以看到通过使用xpath的相对路径和过滤功能使xpath表达式简洁了很多,并且因为忽略了中间层级,对DOM树结构的稳定性依赖降低了很多。

Xpath使用介绍

由于XML/HTML文档都是树形结构,文档中的每一个元素对象都是树形结构中的一个节点,xpath就是帮助我们来对树形结构中的节点进行精确定位的语言

那么,我们在做UI自动化时需要掌握哪些与xpath定位相关的知识点呢?

1、路径表达式

【.】 表示当前节点,xpath以 . 开头的话 即表示这是根节点

【..】 表示当前节点的父节点

【/】 表示选取当前节点的下一级节点

【//】 表示选取当前节点的所有下级节点

【@】 表示选取节点属性

【text()】表示选取节点文本

2、谓语

谓语被括在方括号中,可以视为查找元素的过滤条件,常见的有

使用节点属性过滤 如 .//div[@title='xpath定位']

使用节点索引过滤 如 .//div[1] 索引下标从1开始

使用节点文本过滤 如 .// div[text()='xpath定位']

3、运算符

[+] 加 [-] 减 [] 乘 [div] 除

[=] 等于 [!=]不等于 [<]小于 [ >] 大于

[and] 与 [or] 或

[|] 多节点选取

**4、函数

*

xpath支持的函数非常多,我们在这里只讨论UI自动化测试中常用到的函数,

另外由于主流浏览器现在都不支持xpath2.0,所以我们的讨论范围仅限于xpath1.0

contains(str1,str2) 如果 str1 包含 str2,则返回 true,否则返回 false

substring(str,start,len) 返回从 start 位置开始的指定长度的子字符串。第一个字符的下标是 1

string-length(str) 返回指定字符串str的长度

normalize-space(str) 删除指定字符串的开头和结尾的空白,并把内部的所有空白序列替换为一个,然后返回结果

starts-with(str1,str2) 如果 str1 以 str2 开始,则返回 true,否则返回 false

ends-with(str1,str2) 如果 str1 以 str2 结尾,则返回 true,否则返回 false

not(arg) 返回参数arg的相反的布尔值

5、轴(列举几个常用的)

ancestor 选取当前节点的所有先辈(父、祖父等)。

preceding-sibling 选取当前节点之前的所有同级节点。

following-sibling 选取当前节点之后的所有同级节点。

轴使用语法为 : 轴名称::元素xpath,

比如 .//div[@id='1']//following-sibling::input[@name]

表示选取 id为1的div元素之后同级的所有带有name属性的input元素

实例 : 用Chrome打开猎聘的首页 https://www.liepin.com

首先 ,尝试定位首页的搜索输入框元素

按F12打开Chrome开发工具,查看该元素属性

切换到Console,输入$x(".//input[contains(@placeholder,'输入职位关键词')]")

可以看到 定位到了两个input元素,把鼠标移动到第一个input元素上,搜索栏元素激活,第二个是一个相同的input的元素但是当前是隐藏状态

然后,我们吧xpath改一下,指定取第一个匹配到的元素,这样就可以精确匹配到这个搜索输入框了

如果不希望使用写死索引的方式定位,我们可以再分析下这两个input有什么区别

上面分别是两个input及其容器元素的结构,可以看到第二个input的容器div元素多了个style属性,data-selector也不同,那么我们可以再改造一下xpath

.//div[@data-selector='search-box' and not(contains(@style,'none'))]//input[contains(@placeholder,'输入职位关键词')]

这样 ,我们就定位到了搜索输入框元素 ,这里的xpath定位我们使用到了 contains函数、@属性定位、索引定位、and 与操作 、not函数

接下来再看看下搜索栏下面的行业分类索引链接

假如我们希望能够通过分页文本内容【IT·互联网】来定位到这个a元素

xpath : .//p[@data-selector='subsite-btn']//b[text()='IT·互联网']/..

这里,我们使用了【..】来选取父元素,直接使用【..】来定位父元素比较简单,但是不能加任何过滤条件,

如果还想要对父元素或更上层的元素进行过滤选择的话需要用xpath轴ancestor

我们可以看到,xpath的相对定位是非常灵活并且健壮性较强的一种定位方式,在实际工作中也是使用的非常多的,非常推荐大家使用。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 196,647评论 5 462
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 82,690评论 2 374
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 143,739评论 0 325
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,692评论 1 267
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 61,552评论 5 358
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,410评论 1 275
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,819评论 3 387
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,463评论 0 255
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,752评论 1 294
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,789评论 2 314
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,572评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,414评论 3 315
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,833评论 3 300
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,054评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,345评论 1 254
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,810评论 2 342
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 41,016评论 2 337