Python爬虫基础之XPath语法与lxml库的用法详解


Posted in Python onSeptember 13, 2018

前言

本来打算写的标题是XPath语法,但是想了一下Python中的解析库lxml,使用的是Xpath语法,同样也是效率比较高的解析方法,所以就写成了XPath语法和lxml库的用法

XPath 即为 XML 路径语言,它是一种用来确定 XML(标准通用标记语言的子集)文档中某部分位置的语言。

XPath 基于 XML 的树状结构,提供在数据结构树中找寻节点的能力。 XPath 同样也支持HTML。

XPath 是一门小型的查询语言。

python 中 lxml库 使用的是 Xpath 语法,是效率比较高的解析方法。

下面话不多说了,来一起看看详细的介绍吧

安装

为什么要用这个库呢,因为要写爬虫啊,利用lxml库来解析 HTML 代码,同时lxml也继承了libxml2的特性自动修正HTML代码,利用pip安装即可

pip install lxml

XPath语法

XPath是一门在XML文档中查找信息的语言,可以用于在XML文档中通过元素和属性进行导航

举个栗子 ?

我们可以使用XPath提取网站地图中的所有链接,也就是说可以使用XPath去找我们HTML中的一些具体的东西

节点关系

在XPath中,有七种类型的节点:元素、属性、文本、命名空间、处理指令、注释以及文档节点(或称为根节点)

再举个栗子 ?

<urlset>
<url>
<loc>https://qq52o.me</loc>
<lastmod>2018-04-28T19:00:42+00:00</lastmod>
<changefreq>daily</changefreq>
<priority>1.0</priority>
</url>
</urlset>

第一个:父(Parent)

每个元素以及属性都有一个父

url元素是 loc、lastmod、changefreq以及 priority元素的父

第二个:子(Children)

元素节点可有零个、一个或多个子

loc、lastmod、changefreq以及 priority元素都是url元素的子

第三个:同胞(Sibling)

拥有相同的父的节点

loc、lastmod、changefreq以及 priority元素都是url元素的同胞

第四个:先辈(Ancestor)

某节点的父、父的父,等等

loc元素的先辈是 url元素和 urlset元素

第五个:后代(Descendant)

某个节点的子,子的子,等等

urlset的后代是url、loc、lastmod、changefreq以及 priority元素

如果你分不清楚,就按照子元素从上到下的去找元素节点

选取节点

XPath使用路径表达式在 XML 文档中选取节点,节点是通过沿着路径或者 step 来选取的,也就是上面所说的按照子元素从上到下去找元素节点

这些是最有用的路径表达式 ?

表达式 描述
nodename 选取此节点的所有子节点
/ 从根节点选取
// 从匹配选择的当前节点选择文档中的节点,而不考虑它们的位置
. 选取当前节点
.. 选取当前节点的父节点
@ 选取属性

实例

路径表达式 结果
urlset 选取urlset元素的所有子节点
/urlset 选取根元素 urlset
urlset/url 选取属于urlset的子元素的所有url元素
//url 选取所有url子元素,而不管它们在文档中的位置
urlset//url 选择属于urlset元素的后代的所有url元素,而不管它们位于urlset之下的什么位置
//@href 选取名为href的所有属性

其他XPath语法请参考w3school

XPath实例测试

提取本站网站地图中id属性为content的的子元素h3的内容以及子元素a的href属性,F12去看代码找这个属性

Python爬虫基础之XPath语法与lxml库的用法详解

div的id属性,下面的子元素h3的内容,直接利用 text 方法来获取元素的内容,然后输出

Python爬虫基础之XPath语法与lxml库的用法详解

这里的子元素层级关系必须按顺序写好,不然会报错的

IndexError: list index out of range

这就说明你的XPath规则没写好,list是一个空的,没有一个元素

XPath 是一个非常好用的解析方法,同时也是作为爬虫学习的基础

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对三水点靠木的支持。

Python 相关文章推荐
web.py在SAE中的Session问题解决方法(使用mysql存储)
Jun 24 Python
Python模块包中__init__.py文件功能分析
Jun 14 Python
python2.x实现人民币转大写人民币
Jun 20 Python
Django forms组件的使用教程
Oct 08 Python
VPS CENTOS 上配置python,mysql,nginx,uwsgi,django的方法详解
Jul 01 Python
谈一谈数组拼接tf.concat()和np.concatenate()的区别
Feb 07 Python
PyQt5+python3+pycharm开发环境配置教程
Mar 24 Python
Python figure参数及subplot子图绘制代码
Apr 18 Python
利用Python如何实时检测自身内存占用
May 09 Python
python matlab库简单用法讲解
Dec 31 Python
python 通过使用Yolact训练数据集
Apr 06 Python
python字符串拼接.join()和拆分.split()详解
Nov 23 Python
Python爬虫常用小技巧之设置代理IP
Sep 13 #Python
python集合比较(交集,并集,差集)方法详解
Sep 13 #Python
python中dict字典的查询键值对 遍历 排序 创建 访问 更新 删除基础操作方法
Sep 13 #Python
Python字典创建 遍历 添加等实用基础操作技巧
Sep 13 #Python
python单例模式获取IP代理的方法详解
Sep 13 #Python
如何利用python制作时间戳转换工具详解
Sep 12 #Python
Python get获取页面cookie代码实例
Sep 12 #Python
You might like
PHP使用ob_start生成html页面的方法
2014/11/07 PHP
php写入数据到CSV文件的方法
2015/03/14 PHP
PHP实现可添加水印与生成缩略图的图片处理工具类
2018/01/16 PHP
PHP自定义错误处理的方法分析
2018/12/19 PHP
jQuery EasyUI API 中文文档 - NumberSpinner数值微调器使用介绍
2011/10/21 Javascript
jquery写个checkbox——类似邮箱全选功能
2013/03/19 Javascript
商城常用滚动的焦点图效果代码简单实用
2013/03/28 Javascript
javascript中处理时间戳为日期格式的方法
2014/01/02 Javascript
js校验表单后提交表单的三种方法总结
2014/02/28 Javascript
javascript setinterval 的正确语法如何书写
2014/06/17 Javascript
jquery中EasyUI实现异步树
2015/03/01 Javascript
JavaScript中的函数嵌套使用
2015/06/04 Javascript
详解webpack 如何集成第三方js库
2017/06/29 Javascript
vue与bootstrap实现时间选择器的示例代码
2017/08/26 Javascript
nginx+vue.js实现前后端分离的示例代码
2018/02/12 Javascript
vue中各种通信传值方式总结
2019/02/14 Javascript
使用weixin-java-miniapp配置进行单个小程序的配置详解
2019/03/29 Javascript
浅谈webpack 四个核心概念之Entry
2019/06/12 Javascript
vue v-for直接循环数字实例
2019/11/07 Javascript
mpvue微信小程序开发之实现一个弹幕评论
2019/11/24 Javascript
JS字符串补全方法padStart()和padEnd()
2020/05/27 Javascript
vue.js实现h5机器人聊天(测试版)
2020/07/16 Javascript
vue-openlayers实现地图坐标弹框效果
2020/09/24 Javascript
Python之多线程爬虫抓取网页图片的示例代码
2018/01/10 Python
python函数的作用域及关键字详解
2019/08/20 Python
PYTHON绘制雷达图代码实例
2019/10/15 Python
Python测试线程应用程序过程解析
2019/12/31 Python
python实现随机加减法生成器
2020/02/24 Python
Python如何使用神经网络进行简单文本分类
2021/02/25 Python
基于CSS3制作立体效果导航菜单
2016/01/12 HTML / CSS
贝玲妃美国官方网站:Benefit美国
2016/08/28 全球购物
VIVOBAREFOOT赤脚鞋:让您的脚做自然的事情
2017/06/01 全球购物
马来西亚最大的在线隐形眼镜商店:MrLens
2019/03/27 全球购物
李维斯牛仔裤荷兰官方网站:Levi’s NL
2020/08/23 全球购物
感恩母亲节活动方案
2014/03/04 职场文书
英文商务邀请函范文
2015/01/31 职场文书