XPath语法和lxml模块 xpath(XML Path Language)是一门在XML和HTML文档中查找信息的语言,可用来在XML和HTML文档中对元素和属性进行遍历。
Chrome插件XPath Helper。
安装方法:
Firefox插件Try XPath。
在 XPath 中,有七种类型的节点:元素、属性、文本、命名空间、处理指令、注释以及文档(根)节点。XML 文档是被作为节点树来对待的。树的根被称为文档节点或者根节点。

使用//获取整个页面当中的元素,然后写标签名,然后在写谓语进行提取,比如:
//title[@lang='en']//标签[@属性名='属性值']# 如果想获取html标签下的body标签html/body
只要book标签带有属性都可以通过//book[@*]匹配到
通过在路径表达式中使用|运算符,可以选取若干个路径
# 选取所有book元素以及book元素下所有的title元素//bookstore/book|//book/title


/和//的区别:/代表只获取子节点,//获取子孙节点,一般//用的比较多,当然也要视情况而定
contains:有时候某个属性中包含了多个值,那么可以使用contains函数,示例如下:
//title[contains(@lang,'en')]谓词中下标是从1开始的,不是从0开始的
lxml 是 一个HTML/XML的解析器,主要的功能是如何解析和提取 HTML/XML 数据。
lxml和正则一样,也是用 C 实现的,是一款高性能的 Python HTML/XML 解析器,我们可以利用之前学习的XPath语法,来快速的定位特定元素以及节点信息。
??lxml python 官方文档:http://lxml.de/index.html
??需要安装C语言库,可使用 pip 安装:pip install lxml
我们可以利用他来解析HTML代码,并且在解析HTML代码的时候,如果HTML代码不规范,他会自动的进行补全
from lxml import etreetext = '''<div> <ul> <li ><a href="link1.html">first item</a></li> <li ><a href="link2.html">second item</a></li> <li ><a href="link3.html">third item</a></li> <li ><a href="link4.html">fourth item</a></li> <li ><a href="link5.html">fifth item</a> </ul> </div>'''# 将字符串解析为html文档html = etree.HTML(text)print(html)# 按字符串序列化htmlresult = etree.tostring(html).decode('utf-8')print(result)#读取html = etree.parse('hello.html')result = etree.tostring(html).decode('utf-8')print(result)<!-- hello.html --><div> <ul> <li ><a href="link1.html">first item</a></li> <li ><a href="link2.html">second item</a></li> <li ><a href="link3.html"><span >third item</span></a></li> <li ><a href="link4.html">fourth item</a></li> <li ><a href="link5.html">fifth item</a></li> </ul> </div>语法练习
from lxml import etreehtml = etree.parse('hello.html')# 获取所有li标签:# result = html.xpath('//li')# print(result)# for i in result:# print(etree.tostring(i))# 获取所有li元素下的所有class属性的值:# result = html.xpath('//li/@class')# print(result)# 获取li标签下href为www.baidu.com的a标签:# result = html.xpath('//li/a[@href="www.baidu.com"]')# print(result)# 获取li标签下所有span标签:# result = html.xpath('//li//span')# print(result)# 获取li标签下的a标签里的所有class:# result = html.xpath('//li/a//@class')# print(result)# 获取最后一个li的a的href属性对应的值:# result = html.xpath('//li[last()]/a/@href')# print(result)# 获取倒数第二个li元素的内容:# result = html.xpath('//li[last()-1]/a')# print(result)# print(result[0].text)# 获取倒数第二个li元素的内容的第二种方式:result = html.xpath('//li[last()-1]/a/text()')print(result)