Xpath定位绝密版本
xpath的作用就是两个字“定位”,
运用各种方法进行快速准确的定位,推荐两个非常有用的的firefox工具:firebug和xpath checker 在 XPath 中,
有七种类型的节点:元素、属性、文本、命名空间、处理指令、注释以及文档(根)节点
XML 文档是被作为节点树来对待的。树的根被称为文档节点或者根节点
节点关系
<bookstore>
<book>
<title>Harry Potter</title>
<author>J K. Rowling</author>
<year>2005</year>
<price>29.99</price>
</book>
</bookstore>
父节点:每个元素及属性都有父节点。
子节点:元素节点可以有0个或1个或n个子节点。
同胞节点:拥有相同父节点的节点。
先辈节点:某个节点的父节点,祖父节点等等。
后代节点:某个节点的子节点,孙子节点等等。
book 元素是 title、author、year 以及 price 元素的父节点
title、author、year 以及 price 元素都是 book 元素的子节点
title、author、year 以及 price 元素都是同胞节点
title 元素的先辈是 book 元素和 bookstore 元素
bookstore 的后代是 book、title、author、year 以及 price 元素 bookstore 选取 bookstore 元素的所有子节点
/bookstore 选取根元素 bookstore
bookstore/book 选取属于 bookstore 的子元素中的所有 book 元素
bookstore//book 选择属于 bookstore 的后代中的所有 book 元素,
而不管它们位于 bookstore 之下的什么位置
//book 选取所有 book 子元素,而不管它们在文档中的位置
//@lang 选取名为 lang 的所有属性 Predicates谓语用来查找某个特定的节点或者包含某个指定的值的节点
谓语被嵌在方括号中 /bookstore/book[1] 选取属于 bookstore 子元素的第一个 book 元素
/bookstore/book[last()] 选取属于 bookstore 子元素的最后一个 book 元素
/bookstore/book[last()-1] 选取属于 bookstore 子元素的倒数第二个 book 元素
/bookstore/book[position()<] 选取最前面的两个属于 bookstore 元素的子元素的 book 元素
//title[@lang] 选取所有拥有名为 lang 的属性的 title 元素
/bookstore/book[price>35.00] 选取 bookstore 元素的所有 book 元素,
且其中的 price 元素的值须大于 35.00
/bookstore/* 选取 bookstore 元素的所有子元素
//* 选取文档中的所有元素
//title[@*] 选取所有带有属性的 title 元素
通过在路径表达式中使用“|”运算符,您可以选取若干个路径
//book/title | //book/price 选取 book 元素的所有 title 和 price 子元素节点
//title | //price 选取文档中的所有 title 和 price 元素节点
/bookstore/book/title | //price 选取属于 bookstore 元素的 book 元素的所有 title 元素,
以及文档中所有的 price 元素
xpath语法
. 代表当前节点路径
..代表当前节点路径的父节点
* 匹配任何标签元素节点
@*匹配人和属性节点
node()匹配任何类型的节点
/ 从根节点选取
// 从匹配选择的当前节点选择文档中的节点,而不考虑它们的位置
@ 选取属性
定位
1.依靠自己属性,文本定位
//td[text()='xxx']
//div[contains(@class,'xxx')]
//div[@class='xxx' and @type='xxx']
2.依靠父节点定位
//div[@class='xxx']/div
//div[@id='xxx']/div
3.依靠子节点定位
//div[div[@id='xxx']]
//div[div[@name='xxx']]
4.混合型
//div[div[@name='xxx']]/img
//td[a/font[contains(text(),'xxx')]]//input[@type='xxx']
xpath的学习-拓展
1.following-sibling
following-sibling即为“选择当前节点之后的所有同级节点”,那么没有加上“sibling”关键字的,搜索的就是之上/之下的所有节点,忽略同级概念,例如:
<div>
<input id="123">
<input>
</div>
要定位第二个input://input[@id='123']/following-sibling::input 2.preceding-sibling
preceding-sibling的解释是“选取当前节点之前的所有同级节点”,那么没有加上“sibling”关键字的,搜索的就是之上/之下的所有节点,忽略同级概念,
preceding-sibling和following-sibling是刚好相反的
<div>
<span>text</span>
<input id="123">
</div>
要定位第二个input://input[@id='123']/preceding-sibling::span 3.contains
和字面意思一样就是包含,例如://div[contains(@class,'xxx')] 4.starts-with
和字面意思一样就是以某某开头,例如://input[starts-with(@class,'xxx')] 5.not
就是否定的意思
比如找一个id不为123的input:input[not[id='123']]
又如找一个文本中不包含xxx字段的span://span[not(contains(text(),'xxx'))]
xpath的学习-补充
绝对路径 html/body/div/span[2]/input[2] 中间结构变化,就失效
相对路径 //开始,在整个html source里找,不管在什么位置
索引[x] //div/input[2] div下面第二个input
position()=2
position()>3
position()<3
last()
last()-1
属性定位 //div[@class] 有class属性的div
属性值定位, //div[@class='xxx'] 功能关键字
1.常用
and或者[][],
比如://span[@name='xxx' and text()='xxx']
也是可以写成//span[@name='xxx'][text()='xxx'] or,比如以上面html为例子,定位文本为test position()5和test position()4的span://div[@id='positions']/span[text()='test position()5' or text()='test position()4']
not,
contains,
starts-with
ends-with 在xpath中是没有这个的
通配符 *
比如//span[@*="xxx"]指定位span中任意属性包含xxx的
比如//*[@*="xxx"]指定位页面中任意属性保护xxx的标签 测试实例
By.xpath(".//a/span[contains(text(),'前端开发')]")
By.xpath("//span[@name='username' and text()='用户名']")
By.xpath("//div[class='item']/li[3]")
By.xpath("//*[@id="main"]/div[2]/div/div[9]/div[4]")

xpath=/html/body/form[1] - 绝对路径(如果HTML只是稍微改变,会中断)
//form[1] - HTML中的第一个表单元素
xpath=//form[@id='loginForm'] - 属性名为“id”和值为“loginForm”的表单元素
xpath=//form[input/@name='username'] - 具有输入子元素的第一个表单元素,其属性名为“name”,值为“username”
//input[@name='username'] - 第一个输入元素的属性名为“名称”和值“用户名”
//form[@id='loginForm']/input[1] - 首先输入具有名为“id”的属性和值“loginForm”的表单元素的子元素
//input[@name='continue'][@type='button'] - 输入属性名为'name',值为'continue',属性名为'type',值'button'
//form[@id='loginForm']/input[4] - 表单元素的第四个输入子元素,其属性名为“id”,值为“loginForm”
Xpath定位绝密版本的更多相关文章
- UI自动化测试(二)浏览器操作及对元素的定位方法(xpath定位和css定位详解)
Selenium下的Webdriver工具支持FireFox(geckodriver). IE(InternetExplorerDriver).Chrome(ChromeDriver). Opera( ...
- 初探UiAutomator2.0中使用Xpath定位元素
J 今天的主题是讲一下在使用过程中遇到的一个问题,如何在UiAutomator2.0中使用Xpath定位元素? 背景 现在的app在打包成apk的时候都是有加固处理的,各种混淆加固,所以已经破坏了或扰 ...
- java selenium (六) XPath 定位
xpath 的定位方法, 非常强大. 使用这种方法几乎可以定位到页面上的任意元素. 阅读目录 什么是xpath xpath 是XML Path的简称, 由于HTML文档本身就是一个标准的XML页面, ...
- 常用的CSS定位,XPath定位和JPath定位
CSS定位 举例 描述 div#menu id为menu的div元素 div.action-btn.ok-btn class为action-btn和ok-btn的div元素 table#emailLi ...
- selenium之xpath定位和input文本
selenium之xpath定位和input文本 xpath简单定位: 打开浏览器的F12 在自己需要定位的元素的那里右键 选择copy->xpath selenium获取input下的文本: ...
- 5.5.8 XPath定位
1.什么是XPath XPath定位方式是自动化测试定位技术中的必杀技,几乎可以解决所有的定位难题.它是XML Path语言的缩写,主要用于在XML 文档中选择文档中的节点.基于XML树状文档结构,X ...
- selenium+python自动化之xpath定位
在上一篇简单的介绍了用工具查看目标元素的xpath地址,工具查看比较死板,不够灵活,有时候直接复制粘贴会定位不到.这个时候就需要自己手动的去写xpath了,这一篇详细讲解xpath的一些语法. 什么是 ...
- Xpath定位大全
selenium使用Xpath定位之完整篇 其中有一片文章提到了xpath元素定位,但是该文章中有些并不能适应一些特殊与个性化的场景.在文本中提供xpath元素的定位终极篇,你一定能在这里找到你需 ...
- appium的xpath定位
做自动化,元素定位是我们遇到的第一个困难.总是会有各种各样的问题,导致我们定位不到元素.前面一篇博客也写了元素定位的几种方法,今天主要分享一下xpath的定位方法. 这里我们仍然拿计算器举例. 比如我 ...
随机推荐
- maven---工程建立及目录添加--
刚开始建立maven工程目录1: 添加web能力: 选中工程鼠标右击点MyEclipse添加web能力: 然后: 关键点:remove掉Excluded:** 添加javaEE5库 确保web: 建p ...
- Python-Redis的发布与订阅
封装的redis_config # -*- coding:utf-8 -*- __author__ = "MuT6 Sch01aR" import redis class Redi ...
- delphi 线程教学第一节:初识多线程
第一节:初识多线程 1.为什么要学习多线程编程? 多线程(多个线程同时运行)编程,亦可称之为异步编程. 有了多线程,主界面才不会因为耗时代码而造成“假死“状态. 有了多线程,才能使多个任务同时 ...
- 【java并发编程艺术学习】(三)第二章 java并发机制的底层实现原理 学习记录(一) volatile
章节介绍 这一章节主要学习java并发机制的底层实现原理.主要学习volatile.synchronized和原子操作的实现原理.Java中的大部分容器和框架都依赖于此. Java代码 ==经过编译= ...
- k8s 基础 核心概念
Pod pod是若干相关容器的集合,Pod包含的容器运行在同一台宿主机上,这些容器使用相同的网络命名空间,ip地址和端口,相互之间能通过localhost来发现和通信.另外,这些容器还可共享一块存储空 ...
- ViewPage+Fragment(仿微信切换带通知)
第一步 : 布局文件 activity_main.xml <?xml version="1.0" encoding="utf-8"?> <Li ...
- C++中的对象的赋值和复制
对象的赋值 如果对一个类定义了两个或多个对象,则这些同类的对象之间可以互相赋值,或者说,一个对象的值可以赋给另一个同类的对象.这里所指的对象的值是指对象中所有数据成员的值. 对象之间的赋值也是通过赋值 ...
- hdu1063
#include<iostream> #include<string> using namespace std; struct BigReal //高精度实数 { int le ...
- hdu1047
#include<stdio.h>#include<string>#include<iostream>using namespace std; //高精度加法//只 ...
- 20169201 使用Metaspoit攻击MS08-067实验
MS08-067漏洞介绍 MS08-067漏洞的全称为"Windows Server服务RPC请求缓冲区溢出漏洞",如果用户在受影响的系统上收到特制的 RPC 请求,则该漏洞可能允 ...