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为plantclass为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选择器(二)的更多相关文章

  1. selenium中CSS选择器定位

    selenium元素定位,CSS选择器定位效率会高很多. CSS选择器用于选择你想要的元素的样式的模式.表格摘自“菜鸟教程”,具体用法可去查阅 选择器 示例 示例说明 CSS .class .intr ...

  2. css 选择器二

    2.4 盒模型 2.4.1 定义 在CSS中,"box model"这一术语是用来设计和布局时使用,然后在网页中基本上都会显示一些方方正正的盒子.我们称为这种盒子叫盒模型. 盒模型 ...

  3. Scrapy基础(五) ------css选择器基础

    基本语法: *                  选择所有节点#container         选择id为container的节点.container      选择所有class包含contai ...

  4. CSS的引入方式及CSS选择器

    一 CSS介绍 现在的互联网前端分三层: a.HTML:超文本标记语言.从语义的角度描述页面结构. b.CSS:层叠样式表.从审美的角度负责页面样式. c.JS:JavaScript .从交互的角度描 ...

  5. 01--CSS的引入方式及CSS选择器

    一 CSS介绍 现在的互联网前端分三层: a.HTML:超文本标记语言.从语义的角度描述页面结构. b.CSS:层叠样式表.从审美的角度负责页面样式. c.JS:JavaScript .从交互的角度描 ...

  6. day 42 01--CSS的引入方式及CSS选择器

    01--CSS的引入方式及CSS选择器   本节目录 一 CSS介绍 二 行内样式 三 内接样式 四 外接样式 五 CSS的选择器 六 CSS的高级选择器 七 CSS的属性选择器 八 CSS的伪类选择 ...

  7. Selenium系列(十二) - 自动化必备知识之CSS选择器的详细使用

    如果你还想从头学起Selenium,可以看看这个系列的文章哦! https://www.cnblogs.com/poloyy/category/1680176.html 其次,如果你不懂前端基础知识, ...

  8. 最常用的五类CSS选择器

    一些新手朋友对选择器一知半解,不知道在什么情况下运用什么样的选择器,这是一个比较头疼的问题,针对新手朋友,对CSS选择器作一些简单的说明,希望能对大家的学习工作有一定的帮助,更多的CSS知识请参考We ...

  9. 还需要学习的十二种CSS选择器

    在前面的文章中,我们在介绍了<五种你必须彻底了解的CSS选择器>,现在向大家介绍,还需要学习的另外十二种CSS选择器.如果你还没有用过,就好好学习一下,如果你已经熟知了就当是温习. 一.X ...

随机推荐

  1. 微信小程序 wepy框架 之拦截器intercepter使用

    1,在使用wepy框架创建的项目下 找到src/app.wpy 2,在app.wpy constructor方法中添加 super(); this.use('promisify');//启用ES6 p ...

  2. sqlserver数据库批量插入-SqlBulkCopy

    当想在数据库中插入大量数据时,使用insert 不仅效率低,而且会导致一系列的数据库性能问题 当使用insert语句进行插入数据时.我使用了两种方式: 每次插入数据时,都只插入一条数据库,这个会导致每 ...

  3. Git很麻烦?只要掌握这几个命令,轻松将代码提交远程仓库

    在上一章节,跟大家介绍了拉取代码的操作,简单暴力.这一章节要介绍的是如何将现有的项目,直接提交到仓库. 现在,如果大家有一个项目要提交到GitHub仓库,安装上一张的方法,需要先在GitHub上建一个 ...

  4. centos7配置阿里yum源

    首先刚刚安装完的centos并不像Ubuntu系统那样有很多的源来可以供您使用 所以我们需要通过下载阿里云的yum源在下载epel-release.noarch扩展包就可以了 操作如下: 1.首先这是 ...

  5. global、nonlocal关键字

    一:global:在函数内部引用/声明全局变量 在自定义函数时,有时候需要引用函数外的一些全局变量,如果不需要修改全局变量的内容,则可以直接引用,像下面这样: c = 999 def func(): ...

  6. 两种最常用的 HTTP 操作方法是:GET 和 POST。

    什么是 HTTP? 超文本传输协议(HTTP)的设计目的是保证客户机与服务器之间的通信. HTTP 的工作方式是客户机与服务器之间的请求-应答协议. web 浏览器可能是客户端,而计算机上的网络应用程 ...

  7. Python——面向对象(类)的基础疑难点

    相信用Python写def函数大家都信手拈来了,但Python作为面向对象的编程语言,怎么能浪费呢? 那问题来了.什么是类呢?什么是实例?什么是对象?方法是什么??属性又是什么???继承?封装?多态? ...

  8. Redisson基本用法

    1.  Redisson Redisson是Redis官方推荐的Java版的Redis客户端.它提供的功能非常多,也非常强大,此处我们只用它的分布式锁功能. https://github.com/re ...

  9. Maven发布封装到中央仓库时候报错:no default secret key: No secret key

    今天因为发布swagger-spring-boot-starter做一个问题的修复,然后碰到了下面这个问题,记录一下解决过程,帮助后续碰到类似问题的童鞋: *gpg: WARNING: "- ...

  10. Python中定义只读属性

    Python是面向对象(OOP)的语言, 而且在OOP这条路上比Java走得更彻底, 因为在Python里, 一切皆对象, 包括int, float等基本数据类型. 在Java里, 若要为一个类定义只 ...