什么是XPath?
xpath(XML Path Language)是一门在XML和HTML文档中查找信息的语言,可用来在XML和HTML文档中对元素和属性进行遍历。
XPath开发工具
Chrome插件XPath Helper。
Firefox插件Try XPath。
XPath语法
选取节点:
XPath 使用路径表达式来选取 XML 文档中的节点或者节点集。这些路径表达式和我们在常规的电脑文件系统中看到的表达式非常相似。
表达式
描述
示例
结果
nodename
选取此节点的所有子节点
bookstore
选取bookstore下所有的子节点
/
如果是在最前面,代表从根节点选取。否则选择某节点下的某个节点
/bookstore
选取根元素下所有的bookstore节点
//
从全局节点中选择节点,随便在哪个位置
//book
从全局节点中找到所有的book节点
@
选取某个节点的属性
//book[@price]
选择所有拥有price属性的book节点
.
当前节点
./a
选取当前节点下的a标签
谓语:
谓语用来查找某个特定的节点或者包含某个指定的值的节点,被嵌在方括号中。
在下面的表格中,我们列出了带有谓语的一些路径表达式,以及表达式的结果:
路径表达式
描述
/bookstore/book[1]
选取bookstore下的第一个子元素
/bookstore/book[last()]
选取bookstore下的倒数第二个book元素。
bookstore/book[position()<3]
选取bookstore下前面两个子元素。
//book[@price]
选取拥有price属性的book元素
//book[@price=10]
选取所有属性price等于10的book元素
//book[contains(@class,'name')]
选取所有book元素下class属性包含有name参数
通配符
*表示通配符。
通配符
描述
示例
结果
*
匹配任意节点
/bookstore/*
选取bookstore下的所有子元素。
@*
匹配节点中的任何属性
//book[@*]
选取所有带有属性的book元素。
选取多个路径:
通过在路径表达式中使用“|”运算符,可以选取若干个路径。
示例如下:
//bookstore/book | //book/title
# 选取所有book元素以及book元素下所有的title元素
运算符:
lxml库
lxml 是 一个HTML/XML的解析器,主要的功能是如何解析和提取 HTML/XML 数据。
lxml和正则一样,也是用 C 实现的,是一款高性能的 Python HTML/XML 解析器,我们可以利用之前学习的XPath语法,来快速的定位特定元素以及节点信息。
需要安装C语言库,可使用 pip 安装:pip install lxml
基本使用:
我们可以利用他来解析HTML代码,并且在解析HTML代码的时候,如果HTML代码不规范,他会自动的进行补全。示例代码如下:
# 使用 lxml 的 etree 库
from lxml import etree
text = '''
- first item
- second item
- third item
- fourth item
- fifth item # 注意,此处缺少一个 闭合标签
'''
#利用etree.HTML,将字符串解析为HTML文档
html = etree.HTML(text)
# 按字符串序列化HTML文档
result = etree.tostring(html)
print(result)
输入结果如下:
可以看到。lxml会自动修改HTML代码。例子中不仅补全了li标签,还添加了body,html标签。
从文件中读取html代码:
除了直接使用字符串进行解析,lxml还支持从文件中读取内容。我们新建一个hello.html文件: