绝对路径选择

从根节点开始的,到某个节点,每层都依次写下来,每层之间用 / 分隔的表达式,就是某元素的 绝对路径
  • Xpath : /html/body/div
  • CSS : html>body>div

相对路径选择

选择所有div元素里面的子节点p
  • Xpath : //div//p
  • CSS :
    1. 选择直接子元素(父元素是div的p元素)div>p
    2. 选择后代子元素(div元素里的所有p元素)div p

通配符*

选择所有div节点的所有直接子节点
  • Xpath : //div/*
  • CSS : div>*

根据属性选择

选择所有class为a的b元素
  • Xpath : //b[@class='a']
  • CSS : .a
选择style属性为color的所有元素
  • Xpath : //*[@style='color']
  • CSS : [style='color']
选择a属性包含b的所有元素
  • Xpath : //*[contains(@a,'b')]
  • CSS : [a*='b']
选择a属性开头为b的所有元素
  • Xpath : //*[starts-with(@a,'b')]
  • CSS : [a^='b']
选择a属性结尾为b的所有元素(xpath2.0语法,浏览器不支持)
  • Xpath : //*[ends-with(@a,'b')]
  • CSS : [a$='b']
选择a属性包含a1,b属性开头b1,c属性结尾为c1的d元素
  • CSS : d[a*='a1'][b^='b1'][c$='c1']

按次序选择元素

选择父元素为div中的p类型第2个子元素
  • Xpath : //div/p[2]
  • CSS : div p:nth-child(2)
选择父元素为div的第2个子元素
  • Xpath : //div/*[2]
  • CSS : div :nth-child(2)
选取p类型倒数第2个子元素
  • Xpath : //p[last()-1]
  • CSS : p:nth-last-child(2)
选择a元素的第n个p子节点
  • CSS : a p:nth-of-type(n)
选择a元素的倒数第n个p子节点
  • CSS : a p:nth-last-of-type(n)
选择a元素的偶数子节点
  • CSS : a p:nth-of-type(n)
选择a元素的奇数子节点
  • CSS : a :nth-child(even)
选择a元素的p类型的偶数子节点
  • CSS : a p:nth-of-type(even)
选择a元素的p类型的奇数子节点
  • CSS : a p:nth-of-type(even)

按范围选择元素

选取option类型第1到2个子元素
  • Xpath : //option[position()<=2]
选择class属性为a的前3个子元素
  • Xpath : //*[@class='a']/*[position()<=3]
选择class属性为a的后3个子元素
  • Xpath : //*[@class='a']/*[position()>=last()-2]

组选择

选所有class为a的元素,和所有id为b的元素
  • Xpath : //*[@class='a'] | //*[@id='b']
  • CSS : .a , #b

根据子节点选择父节点

父节点没有特征,但子节点有特征时,可通过子节点定位父节点
查找后2代元素包含a元素的节点
  • Xpath : //a/../..

兄弟节点选择

选择 class 为 a 的元素的所有后续兄弟节点
  • Xpath : //*[@class='a']/following-sibling::*
  • CSS : .a ~ *
选择 class 为 a 的元素的所有前置兄弟节点
  • Xpath : //*[@class='a']/preceding-sibling::*
  • CSS : 不支持

selenium用css、xpath表达式进行元素定位的更多相关文章

  1. Python3.x:Selenium中的webdriver进行页面元素定位

    Python3.x:Selenium中的webdriver进行页面元素定位 页面上的元素就像人一样,有各种属性,比如元素名字,元素id,元素属性(class属性,name属性)等等.webdriver ...

  2. 网络爬虫之Selenium模块和Xpath表达式+Lxml解析库的使用

    实际生产环境下,我们一般使用lxml的xpath来解析出我们想要的数据,本篇博客将重点整理Selenium和Xpath表达式,关于CSS选择器,将另外再整理一篇! 一.介绍: selenium最初是一 ...

  3. selenium使用笔记(三)——元素定位

    selenium进行自动化测试的一个很重要的东西那就是元素定位,如果元素都没法定位就无法操作它,也就无法进行自动化测试了.网上对于元素定位有很多的介绍,很详细很详细的,但是依然有很多新手总是会遇到无法 ...

  4. selenium自动化测试——常见的八种元素定位方法

    selenium常用的八种元素定位方法 1.通过 id 定位:find_element_by_id() 2.通过 name 定位:find_element_by_name() 3.通过 tag 定位: ...

  5. Python+Selenium笔记(六):元素定位

      (一)  前言 Web应用以及包含超文本标记语言(HTML).层叠样式表(CSS).JS脚本的WEB页面,基于用户的操作(例如点击提交按钮),浏览器向WEB服务器发送请求,WEB服务器响应请求,返 ...

  6. selenium(1)-详细解读元素定位的八种方式

    安装selenium和下载webdriver 安装selenium pip install selenium pip install selenium  -U  (判断是否有最新版本) 下载drive ...

  7. python+selenium笔记(一):元素定位方法

    一.环境准备: 1.浏览器选择:Firefox 2.安装插件:Firebug和FirePath(设置>附加组件>搜索:输入插件名称>下载安装后重启浏览器) 3.安装完成后,页面右上角 ...

  8. Selenium基础知识(8大元素定位概说)

    1. By.name() 页面源码如下: [html] : <button id="gbqfba"aria-label="Google Search" n ...

  9. Selenium+Python系列(二) - 元素定位那些事

    一.写在前面 今天一实习生小孩问我,说哥你自动化学了多久才会的,咋学的? 自学三个月吧,真的是硬磕呀,当时没人给讲! 其实,学什么都一样,真的就是你想改变的决心有多强罢了. 二.元素定位 这部分内容可 ...

随机推荐

  1. 跟我一起写 Makefile(五)

    六.多目标 Makefile的规则中的目标可以不止一个,其支持多目标,有可能我们的多个目标同时依赖于一个文件,并且其生成的命令大体类似.于是我们就能把其合并起来.当然,多个目标的生成规则的执行命令是同 ...

  2. Terracotta 2.7.2 Admin Console Guide

    http://www.terracotta.org/confluence/display/docs27/Admin+Console+Guide#AdminConsoleGuide-Roots

  3. 用SamInside破解Windows登录密码

    用小马PE的USB-HDD+格式制作启动优盘: 笔记本启动时按ESC键,选择USB启动: 进入WinPE后,将%SystemRoot%/system32/config全部拷贝出来(WinXP这个文件夹 ...

  4. 列出文件夹中分级目录java

    package test; import java.io.File; public class exportFileName { public static void main(String[] ar ...

  5. SpringBoot开发二十四-Redis入门以及Spring整合Redis

    需求介绍 安装 Redis,熟悉 Redis 的命令以及整合Redis,在Spring 中使用Redis. 代码实现 Redis 内置了 16 个库,索引是 0-15 ,默认选择第 0 个 Redis ...

  6. CobaltStrike去除流量特征

    CobaltStrike去除流量特征 ​普通CS没有做流量混淆会被防火墙拦住流量,所以偶尔会看到CS上线了机器但是进行任何操作都没有反应.这里尝试一下做流量混淆.参考网上的文章,大部分是两种方法,一种 ...

  7. HTTP头参数详解及其中的危险

    一.重要的头参数 user_agent 发出请求的用户信息 X-Forwarded-For 表示 HTTP 请求端真实 IP(格式:X-Forwarded-For: client, proxy1, p ...

  8. C#中的几种锁:用户模式锁、内核模式锁、动态计数、监视锁

    参考网址: https://blog.csdn.net/weixin_43989331/article/details/105356008 C#中的几种锁:用户模式锁.内核模式锁.动态计数.监视锁介绍 ...

  9. Qt元对象和属性系统详解

    Qt 是一个用标准 C++ 编写的跨平台开发类库,它对标准 C++ 进行了扩展,引入了元对象系统.信号与槽.属性等特性,使应用程序的开发变得更高效. 本节将介绍 Qt 的这些核心特点,对于理解和编写高 ...

  10. 菜鸟攻略–C语言多文件编程初探(二):使用 gcc 手动编译多文件 C 程序

    step1:下载安装 Dev-C++ 已经安装了 Dev-C++ 或系统中的可以跳过这步.去官网下载 Dev-C++.我昨天下载,发现有点慢,所以我把安装文件放到百度网盘了,供大家下载,下载链接为:h ...