Selenium学习之==>Xpath使用方法

一、什么是Xpath

XPath是XML的路径语言,通俗一点讲就是通过元素的路径来查找到这个标签元素。

工具

Xpath的练习建议大家安装火狐浏览器后,下载插件,FireBug。由于最新版火狐不再支持FireBug等开发工具,可以通过https://ftp.mozilla.org/pub/firefox/releases/ 下载49版本以下的火狐就可以增加Firebug等扩展了。

二、Xpath的使用方法

注:默认死格式 先写 //* 代表定位页面下所有元素

1、Xpath通过标签的属性定位

 1 @代表以属性定位,后面可以接标签中任意属性
 2 通过ID定位
 3 //*[@id='i1']
 4 
 5 通过Class定位
 6 //*[@class='pg-header']
 7 
 8 通过Name定位
 9 //*[@name='username']
10 
11 通过Type定位
12 //*[@ type='button']

2、当标签的属性重合时,Xpath提供了通过标签来进行过滤

1 获取所有input标签元素
2 //input
3 
4 获取placeholder='用户名'的input标签元素
5 //input[@placeholder='用户名']   这种方式比//*要快
6 
7 当出现重复时可以使用下标定位,从1开始
8 //div[@class='inner'][2] 

3、当标签页重复时,Xpath提供了层级过滤

例如:找不到儿子,那么就先找他的爸爸,实在不行可以在找他的爷爷

1 支持通过 / 进行层级递进,找到符合层级关系的标签
2 //form/div/input[@placeholder="用户名"]
3 
4 当层级都重复时,可以通过单个层级的属性进行定位
5 //form/div[@class='login-user']/input

4、一个元素它的兄弟元素跟它的标签一样,这时候无法通过层级定位到。Xpath提供了索引过滤

1 通过索引,在List中定位属性,与python的索引有些差别,Xpath从1开始
2 //select[@name='city'][1]/option[1]

5、上面集中如果都用上了之后还重复的话,我们就可以使用Xpath提供的终极神器,逻辑运算定位:and和or

通过and来缩小过滤的范围,只有条件都符合时才能定位到
//select[@name='city' and @size='4' and @multiple="multiple"]

or就相反了,只要这些筛选中,其中一个出现那么久匹配到了
//select[@name='city' or @size='4']

 

posted on 2018-07-20 18:13  破解孤独  阅读(712)  评论(0编辑  收藏  举报

导航