slenium的xpath几种定位方式
练习地址,以下面地址为例:
http://www.w3school.com.cn/example/xmle/books.xml
1. 查找book对象
//book #所有的数
//book[1] #第一本书
//book[last()] 倒数第一本:
//表示从目录任意位置查找,/表示按照目录顺序查找
倒数第二本://book[last()-1]
2.属性查找@:
//book[@category="cooking"] 表示查找属性category为cooking的内容
1. 逻辑表达式
And查找
//book[@category="web" and @cover="paperback"]
Or查找
//book[@category="web" or @cover="paperback"]
非查找控件
//book[@category!="web"]
Not查找
//year[not(.=2005)]
意思是:查找year内容不为2005的内容 注:“.”就等于text()
//book[not(@category="children")]
模糊匹配
//book/title[contains(text(),'Potter')] :查看book下面title下文本内容包含Potter的控件,只要包含potter就可以定位
精确匹配
//book/year[(text()=2005)]
使用属性值做精确匹配 意思是:查找book下year节点下文本内容为2005的内容
使用大于小于符号定位
//book/year[(text()<2005)] 查找book下year下的文本内容小于2005的
相对定位:
相对定位是两个杠表示“//”,相对路径易维护,
//book//title
绝对路径
绝对定位用一个杠“/”, 绝对路径一个层级变化所有空间都有变化
/bookstore/book[1]/title
轴方式定位:
轴表达式说明parent::* :表示当前节点的父节点元素 ancestor::* :表示当前节点的祖先节点元素 child::* :表示当前节点的子元素 /A/descendant::* 表示A的所有后代元素 self::* :表示当前节点的自身元素 ancestor-or-self::* :表示当前节点的及它的祖先节点元素 descendant-or-self::* :表示当前节点的及它们的后代元素 following-sibling::* :表示当前节点的后序所有兄弟节点元素 preceding-sibling::* :表示当前节点的前面所有兄弟节点元素 following::* :表示当前节点的后序所有元素 preceding::* :表示当前节点的所有元素 |
1.同级元素
/bookstore/book[1]/following-sibling::*
查找books1所有的同级元素都查找出来,“*”表示所有
2./bookstore/book[1]/following-sibling::book[2]
查找book[1]下同级节点下的第二个节点
查找子节点后的节点year
/bookstore/book[2]/year/following-sibling::*
意思是:查找books2下year节点后所有的节点
查找节点前的数据
/bookstore/book[2]/year/preceding-sibling::*
意思是:查找books[2]下year前的同级节点
查找节点的父辈
/bookstore/book[2]/year/parent::*
意思是:查找book[2]的上一个节点,父辈
查找节点的子辈
/bookstore/book[2]/descendant::*
意思是:查找book2的子辈
使用position位置定位
//book[position()=2]
意思:定位books下的第二个节点
也还可以这样
//book[position()>2]
问题://book[contains(.,'Potter')]可以查找到内容而//book[contains(text(),'Potter')]查找不到内容
slenium的xpath几种定位方式的更多相关文章
- Selenium 之18 种定位方式
1 id 定位 driver.find_element_by_id() HTML 规定id 属性在HTML 文档中必须是唯一的.这类似于公民的身份证号,具有很强的唯一性 from selenium i ...
- Selenium学习之==>18种定位方式的使用
Selenium的定位方式一共有18种,单数8种,复数8种,最后两种是前面这16种的底层封装 单数形式8种 # 1.id定位 al = driver.find_element_by_id('i1') ...
- selenuim中18种定位方式
18种定位方式=8种单数形式+8种复数形式+2种底层方案 单数可以确定唯一,复数无法确定: 单数形式定位,返回的是一个元素,复数形式,返回的是一个列表,返回的是当前页面所有符合要求的元素,没有意义 一 ...
- Android中几种定位 方式
介绍的几种定位方式 http://www.cnblogs.com/cuihongyu3503319/p/3863867.html 百度地图api: http://lbsyun.baidu.com/in ...
- android 三种定位方式
http://www.cnblogs.com/oudi/archive/2012/03/22/2411509.html 最近在看android关于定位的方式,查了很多资料,也做了相关实验,在手机上做了 ...
- selenium WebDriver 八种定位方式源码
/* * 多种元素定位方式 */ package com.sfwork; import java.util.List; import org.openqa.selenium.By; import or ...
- position的四种定位方式:static、fixed、relative、absolute
position属性用来规定元素的定位类型和方式 ①position:static 默认值,没有定位,元素出现在正常的流中: ②position:fixed 固定定位 是相对于浏览器窗口来进行定位: ...
- CSS的4种定位方式比较
CSS有四种定位(Positioning)方法:Static,Relative, Absolute和Fixed 元素flow, overlap 相对参照物: 能否用offset( top, left, ...
- css中对position的几种定位方式的最佳诠释
关于元素的position定位的理解,牛客网的hardy给出了一个比较好的理解: 在html中网页可以看成一个立体的空间,一个完整的页面是由很多个页面堆积形成的,如上图所示 CSS中Positio ...
随机推荐
- Taran 缩点【bzoj1529】[POI2005]ska Piggy banks
[bzoj1529][POI2005]ska Piggy banks Description Byteazar 有 N 个小猪存钱罐. 每个存钱罐只能用钥匙打开或者砸开. Byteazar 已经把每个 ...
- 高斯消元法的C++简单实现
高斯消元法 首先,我们导入几个概念. 定义1: 一个矩阵称为阶梯形(行阶梯形),若它有以下三个性质: 1.每一非零行在每一零行之上: 2.某一行的先导元素所在的列位于前一行先导元素的后面: 3.某一行 ...
- HDU1272-小希迷宫
题目链接:点击打开链接 Problem Description 上次Gardon的迷宫城堡小希玩了很久(见Problem B),现在她也想设计一个迷宫让Gardon来走.但是她设计迷宫的思路不一样,首 ...
- 洛谷P1967 货车运输
题目描述 \(A\)国有\(n\)座城市,编号从\(1\)到\(n\),城市之间有\(m\)条双向道路.每一条道路对车辆都有重量限制,简称限重.现在有\(q\)辆货车在运输货物, 司机们想知道每辆车在 ...
- thinkphp5使用phpmailer发送邮件
1.首先让邮箱开启smtp服务,本案例使用163的SMTP服务器: smtp.163.com发送邮件 2.下载phpmailer,在tp项目里的extends文件夹下新建一个文件夹phpmailer, ...
- 关于unique去重
嗯.... unique这个东西也是一个冷门知识..... 但是在有时候它还是比较好用的东西... 下面就在详细代码中看unique是如何实际应用的....它主要是用于数组去重 #include< ...
- Flask虚拟环境连接mysql出现1366的解决方案
报错信息 Warning: (1366, "Incorrect string value: '\xD6\xD0\xB9\xFA\xB1\xEA...' for column 'VARIABL ...
- avro-maven-plugin
<?xml version="1.0" encoding="UTF-8"?> <project xmlns="http://mave ...
- 利用mybatis-generator生成po
import java.io.File; import java.util.ArrayList; import java.util.List; import org.mybatis.generator ...
- 湖南省第十二届大学生计算机程序设计竞赛 problem A 2016
如果 a * b % 2016 == 0 如果a = 1 ,且 a * b % 2016 == 0 考虑一下a = 2017的时候 2017 * b = (2016 + 1) * b % 2016 = ...