Python3网络爬虫开发实战(3)网页数据的解析提取

在这里插入图片描述

一、XPath

XPath 的全称 XML Path Language,即 XML 路径语言,用来在 XML 文档中查找信息,同样适用于 HTML 文档的搜索;

1. 选取节点

表达式 描述
//* 选取所有节点
/ 取子节点
// 取子孙节点
. 选取当前节点
选取当前节点的父节点
/@href 选取节点的href属性
/[@class=“item”] 选择 class 为 item 的子节点
/text() 获取文本
//[contains(@class, “li”)] 选择 class 中包含 li 的子节点
//[contains(@class, “li”) and contains(@class, “ll”)] 选择 class 中包含 li 和 ll 的子节点
//[contains(@class, “li”) and @name=“item”] 选择 class 包含 li 且 name 属性为 item 的节点
//[contains(text(), “内容”] 选择文本中包含内容的节点
//th[@class="id " and position()=1] 选择 class 为 id 的第一个位置的 th 节点
//div[(text()=‘更新’)] 选择文本为 更新 的 div 节点

2. 查找某个特定的节点或者包含某个指定的值的节点

路径表达式 结果
/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 元素。
//title[@lang=‘eng’] 选取所有 title 元素,且这些元素拥有值为 eng 的 lang 属性。
/bookstore/book[price>35.00] 选取 bookstore 元素的所有 book 元素,且其中的 price 元素的值须大于 35.00。
/bookstore/book[price>35.00]//title 选取 bookstore 元素中的 book 元素的所有 title 元素,且其中的 price 元素的值须大于 35.00。

3. XPath 运算符

运算符 描述 实例 返回值
| 计算两个节点集 //book | //cd 返回所有拥有 book 和 cd 元素的节点集
+ 加法 6 + 4 10
- 减法 6 - 4 2
* 乘法 6 * 4 24
div 除法 8 div 4 2
= 等于 price=9.80 如果 price 是 9.80,则返回 true。

如果 price 是 9.90,则返回 false。
!= 不等于 price!=9.80 如果 price 是 9.90,则返回 true。

如果 price 是 9.80,则返回 false。
< 小于 price<9.80 如果 price 是 9.00,则返回 true。

如果 price 是 9.90,则返回 false。
<= 小于或等于 price<=9.80 如果 price 是 9.00,则返回 true。

如果 price 是 9.90,则返回 false。
> 大于 price>9.80 如果 price 是 9.90,则返回 true。

如果 price 是 9.80,则返回 false。
>= 大于或等于 price>=9.80 如果 price 是 9.90,则返回 true。

如果 price 是 9.70,则返回 false。
or price=9.80 or price=9.70 如果 price 是 9.80,则返回 true。

如果 price 是 9.50,则返回 false。
and price>9.00 and price<9.90 如果 price 是 9.80,则返回 true。

如果 price 是 8.50,则返回 false。
mod 计算除法的余数 5 mod 2 1

4. 节点轴

轴名称 结果
ancestor:: 选取当前节点的所有先辈(父、祖父等)。
ancestor-or-self:: 选取当前节点的所有先辈(父、祖父等)以及当前节点本身。
attribute:: 选取当前节点的所有属性。
child:: 选取当前节点的所有子元素。
descendant:: 选取当前节点的所有后代元素(子、孙等)。
descendant-or-self:: 选取当前节点的所有后代元素(子、孙等)以及当前节点本身。
following:: 选取文档中当前节点的结束标签之后的所有节点。
following-sibling:: 选取当前节点之后的所有兄弟节点
namespace:: 选取当前节点的所有命名空间节点。
parent:: 选取当前节点的父节点。
preceding:: 选取文档中当前节点的开始标签之前的所有节点。
preceding-sibling:: 选取当前节点之前的所有同级节点。

5. 利用 lxml 使用 XPath

from lxml import etree

text = 'html 代码'
html = etree.HTML(text) # 会自动修正 HTML 代码
result = html.xpath('xpath 选择器')

二、CSS

选择器 示例 示例说明
.class .intro 选择所有class="intro"的元素
#id #firstname 选择所有id="firstname"的元素
* * 选择所有元素
element p 选择所有<p>元素
element,element div,p 选择所有<div>元素和 <p> 元素
element.class p.hometown 选择所有 class=“hometown” 的<p> 元素
element element div p 选择<div>元素内的所有<p>元素
element>element div>p 选择所有父级是<div> 元素的 <p> 元素
element+element div+p 选择所有紧跟在 <div> 元素之后的第一个 <p> 元素
[attribute] [target]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值