Xpath 和Css Selector使用
Xpath是xml的路径语言,就是通过元素的路径来查找标签元素。
Xpath直接在火狐浏览器的firebug中练习,49版本一下的火狐才能用firebug插件。
Xpath的使用方法
注://* 代表页面下的所有元素 *代表所有的可以被其他的标签代替 @后面是属性定位
1、Xpath 支持ID/Class/Name 定位功能
通过ID定位
//*[@id='inner'] 查找id =inner的标签
通过Class定位
//*[@class='class1'] 查找class=class1的标签
通过Name定位
//*[@type='text']
2、如果标签没有id/class/Name 三种属性,Xpath孩子吃属性定位功能
//*[@value='用户名'] @后面可以跟任何属性
3、当标签属性重复时,Xpath提供了通过标签进行过滤
可以将*换成任意标签名,则可根据标签进行过滤
//input[@palceholder='用户名']
4、当标签页重复时,Xpath提供了层级过滤
跟dom一样找不到child就找兄弟,再不行找爸爸
//div/input[@placeholder='用户名']
当层级都重复时,可以单个层级结合属性定位
//form/div[@class='login-passwd']/input
5、一个元素他的兄弟元素跟他的标签一样,这时候无法通过层级直接定位,但是可以结合下标筛选;
不过Xpath是从1开始的
//form/div[@class='login-passwd']/input[1]
6、Xpath还提供了 and和or 逻辑元算定位
//通过and来缩小过滤的范围,只有条件都符合时才能定位到
Css Selector使用方法
//xpath运行效率最慢,代码冗余最高的
//Cssselector 推荐(w3cshool byid byname全部转成css运行
//都是Css selector运行)
Css Selector 定位实际就是HTML的Css选择器的标签定位
css Selector 在火狐浏览器,下载firefinder结合firebug使用
使用方法:
1、Css Selector 支持ID/Class定位与 html中css的定位方法一样
#id 代表id定位
.后面跟class名字带白哦class定位还提供了多个class同时定位
.c1.c2.c3
2、css Selector 支持标签和属叠加定位
input[value='用户名']
还可以标签叠加 id和class使用
input.c1 叠加class
input#i1 叠加id
3、Css Selector支持杜仲属性组合
Css Selector 的多属性组合选择过滤 没有and 只需要多个[] 连接 就可以
Xpath 和Css Selector使用的更多相关文章
- selenium中Xpath和CSS Selector的使用方法
一.selenium中Xpath的使用方法 1. 什么是xpath? Xpath是XML的路径语言,通俗一点讲就是通过元素的路径来查找这个标签元素 2. 练习Xpath的工具 火狐浏览器,下载插件Fi ...
- selenium:css_selector定位详解(css selector和xpath的比较)
selenium使用css selector和xpath的比较 selenium提供的定位方式(常用) ID NAME CLASS CSS SELECTOR XPATH 推荐的定位方式的优先级 优 ...
- Web自动化测试:xpath & CSS Selector定位
Xpath 和 CSS Selector简介 CSS Selector CSS Selector和Xpath都可以用来表示XML文档中的位置.CSS (Cascading Style Sheets)是 ...
- Scrapy学习系列(一):网页元素查询CSS Selector和XPath Selector
这篇文章主要介绍创建一个简单的spider,顺便介绍一下对网页元素的选取方式(css selector, xpath selector). 第一步:创建spider工程 打开命令行运行以下命令: sc ...
- css selector: xpath:
css selector: $$(".mainLeft>div>h1") xpath: $x(".mainLeft>div>h1") n ...
- Selenium - CSS Selector
Selenium - CSS Selector http://www.cnblogs.com/bugua/archive/2012/08/16/2641647.html 昨天我练习了用CSS(即层 ...
- css selector
文章一: http://www.jb51.net/css/68287.html 去年我学jQuery的时候,曾经做过一点选择器(selector)的笔记,今天是CSS的选择器,以后还有一部分xPath ...
- Selenium 使用css selector (资源来源于网络)
Selenium - CSS Selector 昨天我练习了用CSS(即层叠样式表Cascading Stylesheet) Selector来定位(locate)页面上的元素(Elements).S ...
- UI自动化(九)Css Selector
什么是Css Selector? Css Selector定位实际就是HTML的Css选择器的标签定位 工具 Css Selector的练习建议大家安装火狐浏览器后,下载插件,FireFinder 或 ...
随机推荐
- NDK: ant 错误 [javah] Exception in thread "main" java.lang.NullPointerException 多种解决办法
1.错误提示内容 2.ant脚本对应的内容 <?xml version="1.0" encoding="UTF-8"?> <!-- ===== ...
- vi编辑器中删除文件中所有字符
在命令模式下,将光标移动到文档最上方(使用gg命令),然后输入dG,删除工作区内所有缓存数据. 如果想要删除某行文档以下的内容,将光标移动到文档相应行,然后输入dG即可.
- re:正则表达式,字符串处理的杀手锏
介绍 正则表达式是一种用形式化语法描述的文本匹配模式,可以进行复杂的字符串匹配. Python中的正则表达式通过re模块提供,功能比Python内置的str更强,但是速度没有str提供的方法快. 因此 ...
- 码流回调过快导致下方处理不及时socket阻塞问题
在一个情形中遇到下面一个情况 简述下该图片,对sdk进行二次开发,通过第三方sdk接口获取码流信息.具体实现方式是通过回调函数CallBack_SDK来不停的回调第三方服务的视频流.起初实现逻辑如下: ...
- 004-linux下配置rsyslog日志收集服务器案例 rsyslog+loganalyzer日志服务器,无法添加报表模板解决
centos6系统 client1:192.168.1.33 centos7系统 client2:192.168.1.44 centos7系统 master:192.168.1.55 配置服务端mas ...
- tomcat 搭建网站
基本概念 JDK(Java Development Kit)是Sun Microsystems针对Java开发人员的产品.自从Java推出以来,JDK已经成为使用最广泛的Java SDK.JDK 是整 ...
- silverlight发布设置
HTTP头 - MIME类型.xap xapapplication/x-silverlight .xaml application/xaml+xml
- sparkStreaming(2.1.0)示范代码
package cn.piesat import org.apache.spark.SparkConfimport org.apache.spark.sql.SparkSessionimport or ...
- Activiti使用
Activiti是一个开源的工作流引擎,它实现了BPMN 2.0规范,可以发布设计好的流程定义,并通过api进行流程调度. Activiti 作为一个遵从 Apache 许可的工作流和业务流程管理开源 ...
- c语言中"->"和"."的区别
对于c语言中"->"和"."的区别总结如下: 1.A.B则A为对象或者结构体: 2.A->B则A为指针,->是成员提取,A->B是提取A ...