Selenium(五):CSS选择器(二)
1. CSS选择器
1.1 选择语法联合使用
CSS selector的另一个强大之处在于:选择语法可以联合使用。
html代码:
<div id='bottom'>
<div class='footer1'>
<span class='copyright'>版权</span>
<span class='date'>发布日期:2019-11-26</span>
</div>
<div class='footer2'>
<span>主页
<a href="https://www.cnblogs.com/liuhui0308/">爱编程的小灰灰</a>
</span>
</div>
</div>
比如,我们要选择网页html中的元素
<span class='copyright'>版权</span>
CSS selector表达式可以这样写:
div.footer1 > span.copyright
就是选择一个class属性值为copyright的span节点,并且要求其必须是class属性值为footer1的div节点 的子节点。
也可以更简单:
.footer1 > .copyright
就是选择一个class属性值为copyright的节点(不限类型),并且要求其必须是class属性值为footer1的节点的子节点。
当然这样也是可以的:
.footer1 .copyright
因为子元素同时也是后代元素。
1.2 组选择
如果我们要同时选择所有class为plant和class为animal的元素。怎么办?
这种情况,css选择器可以使用逗号,称之为组选择,像这样:
.raise , .wolf
再比如,我们要同时选择所有tag名为div的元素和id为BYHY的元素,就可以像这样写
div,#BYHY
对应的selenium代码如下:
elements = wd.find_elements_by_css_selector('div,#BYHY')
for element in elements:
print(element.text)
我们再看一个例子:
html代码:
<div id='t1'>
<h3> 唐诗 </h3>
<span>李白</span>
<p>静夜思</p>
<span>杜甫</span>
<p>春夜喜雨</p>
</div> <div id='t2'>
<h3> 宋词 </h3>
<span>辛弃疾</span>
<p>北固亭怀古</p>
</div>
我们要选择所有唐诗里面的作者和诗名,也就是选择所有id为t1里面的span和p元素。
我们是不是应该这样写呢?
#t1 > span,p
这样是不行的,这样写的意思是选择所有id为t1里面的span和所有的p元素。
只能这样写:
#t1 > span , #t1 > p
1.3 按次序选择子节点
html代码:
<div id='t1'>
<h3> 唐诗 </h3>
<span>李白</span>
<p>静夜思</p>
<span>杜甫</span>
<p>春夜喜雨</p>
</div> <div id='t2'>
<h3> 宋词 </h3>
<span>苏轼</span>
<p>赤壁怀古</p>
<p>明月几时有</p>
<p>江城子·乙卯正月二十日夜记梦</p>
<p>蝶恋花·春景</p>
<span>辛弃疾</span>
<p>京口北固亭怀古</p>
<p>青玉案·元夕</p>
<p>西江月·夜行黄沙道中</p>
</div>
1.3.1 父元素的第n个子节点
我们可以指定选择的元素是父元素的第几个子节点,使用nth-child。
比如:
我们要选择唐诗和宋词的第一个作者,
也就是说选择的是第2个子元素,并且是span类型
所以这样可以这样写:
span:nth-child(2)
如果你不加节点类型限制,直接这样写:
:nth-child(2)
就是选择所有位置为第2个的所有元素,不管是什么类型。
1.3.2 父元素的倒数第n个子节点
也可以反过来,选择的是父元素的倒数第n个子节点,使用nth-last-child。
比如:
p:nth-last-child(1)
就是选择第倒数第1个子元素,并且是p元素。
1.3.3 父元素的第几个某类型的子节点
我们可以指定选择的元素是父元素的第几个某类型的子节点,使用nth-of-type。
比如:
我们要选择唐诗和宋词的第一个作者,可以像上面那样思考:选择的是第2个子元素,并且是span类型。
所以可以这样写:
span:nth-child(2)
还可以这样思考,选择的是第1个span类型的子元素。
所以也可以这样写:
span-nth-of-type(1)
1.3.4 父元素的倒数第几个某类型的子节点
当然也可以反过来,选择父元素的倒数第几个某类型的子节点,使用nth-last-of-type。
比如:
p:nth-last-of-type(2)
1.3.5 奇数节点和偶数节点
如果要选择的是父元素的偶数节点,使用nth-child(even)。
比如:
p:nth-child(even)
如果要选择的是父元素的奇数节点,使用nth-child(odd)
p:nth-child(odd)
如果要选择的是父元素的某类型偶数节点,使用nth-of-type(even)。
如果要选择的是父元素的某类型奇数节点,使用nth-of-type(odd)。
1.4 兄弟节点选择
1.4.1 相邻兄弟节点选择
上面的例子里面,我们要选择唐诗和宋词 的第一个作者
还有一种思考方法,就是选择h3后面紧跟着的兄弟节点span。
这就是一种相邻兄弟关系,可以这样写h3+span。
表示元素紧跟关系的是加号。
1.4.2 后续所有兄弟节点选择
如果要选择是选择h3后面所有的兄弟节点span,可以这样写h3 ~ span。
Selenium(五):CSS选择器(二)的更多相关文章
- selenium中CSS选择器定位
selenium元素定位,CSS选择器定位效率会高很多. CSS选择器用于选择你想要的元素的样式的模式.表格摘自“菜鸟教程”,具体用法可去查阅 选择器 示例 示例说明 CSS .class .intr ...
- css 选择器二
2.4 盒模型 2.4.1 定义 在CSS中,"box model"这一术语是用来设计和布局时使用,然后在网页中基本上都会显示一些方方正正的盒子.我们称为这种盒子叫盒模型. 盒模型 ...
- Scrapy基础(五) ------css选择器基础
基本语法: * 选择所有节点#container 选择id为container的节点.container 选择所有class包含contai ...
- CSS的引入方式及CSS选择器
一 CSS介绍 现在的互联网前端分三层: a.HTML:超文本标记语言.从语义的角度描述页面结构. b.CSS:层叠样式表.从审美的角度负责页面样式. c.JS:JavaScript .从交互的角度描 ...
- 01--CSS的引入方式及CSS选择器
一 CSS介绍 现在的互联网前端分三层: a.HTML:超文本标记语言.从语义的角度描述页面结构. b.CSS:层叠样式表.从审美的角度负责页面样式. c.JS:JavaScript .从交互的角度描 ...
- day 42 01--CSS的引入方式及CSS选择器
01--CSS的引入方式及CSS选择器 本节目录 一 CSS介绍 二 行内样式 三 内接样式 四 外接样式 五 CSS的选择器 六 CSS的高级选择器 七 CSS的属性选择器 八 CSS的伪类选择 ...
- Selenium系列(十二) - 自动化必备知识之CSS选择器的详细使用
如果你还想从头学起Selenium,可以看看这个系列的文章哦! https://www.cnblogs.com/poloyy/category/1680176.html 其次,如果你不懂前端基础知识, ...
- 最常用的五类CSS选择器
一些新手朋友对选择器一知半解,不知道在什么情况下运用什么样的选择器,这是一个比较头疼的问题,针对新手朋友,对CSS选择器作一些简单的说明,希望能对大家的学习工作有一定的帮助,更多的CSS知识请参考We ...
- 还需要学习的十二种CSS选择器
在前面的文章中,我们在介绍了<五种你必须彻底了解的CSS选择器>,现在向大家介绍,还需要学习的另外十二种CSS选择器.如果你还没有用过,就好好学习一下,如果你已经熟知了就当是温习. 一.X ...
随机推荐
- Python是什么?你真的了解Python吗?
一.Python是什么相信混迹IT界的很多朋友都知道,Python是近年来最火的一个热点,没有之一.从性质上来讲它和我们熟知的C.java.php等没有什么本质的区别,也是一种开发语言,而且已经进阶到 ...
- Springboot vue.js html 跨域 前后分离 shiro权限 集成代码生成器
本代码为 Springboot vue.js 前后分离 + 跨域 版本 (权限控制到菜单和按钮) 后台框架:springboot2.1.2+ mybaits+maven+接口 前端页面:html + ...
- css 重点知识 和 bug 解决方法
1.图片向下撑大3像素问题 在一个盒子里面放一张图片,默认情况下,图片会向下撑大3像素,有以下几种解决方法: 1.1 给图片添加display:block: 1.2 给图片添加 float:left: ...
- Hadoop入门学习笔记总结系列文章导航
一.为何要学习Hadoop? 这是一个信息爆炸的时代.经过数十年的积累,很多企业都聚集了大量的数据.这些数据也是企业的核心财富之一,怎样从累积的数据里寻找价值,变废为宝炼数成金成为当务之急.但数据增长 ...
- Xposed的新打开方式--Xpatch工作流程分析
1. Xpatch概述 Xpatch是一款利用重打包的方式,使得被处理的Apk启动时自动加载Xposed模块,来实现应用内Hook的工具. 项目地址:https://github.com/WindyS ...
- Java并发的若干基本陷阱、原理及解决方案
勿止于结论:持续探索与求证. 概述 为什么要使用并发 ? 有三点足够信服的理由: 性能提升.单核 CPU 的性能基本抵达瓶颈,充分挖掘多核 CPU 的能力,使得性能提升变成水平可扩展的. 事件本质.世 ...
- java 编译时注解框架 lombok-ex
lombok-ex lombok-ex 是一款类似于 lombok 的编译时注解框架. 编译时注,拥有运行时注解的便利性,和无任何损失的性能. 主要补充一些 lombok 没有实现,且自己会用到的常见 ...
- 转pytorch中训练深度神经网络模型的关键知识点
版权声明:本文为博主原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明. 本文链接:https://blog.csdn.net/weixin_42279044/articl ...
- Android 双屏异显的实现
先说重点 <!-- 显示系统窗口权限 --> <uses-permission android:name="android.permission.SYSTEM_ALERT_ ...
- 有了AOE,妈妈再也不用担心我的模型管理!
前言 越来越多的业务会用到AI相关的技术,大多数的AI模型是部署在云端使用的,毕竟服务端计算更快,管理也更容易.随着终端设备性能提升,在终端使用 AI 模型有了更大的价值,可以更好满足业务对响应实时性 ...