Python中的html5lib和lxml解析器
html5lib是用于解析HTML的纯Python库。它被设计为符合WHATWGHTML规范,所有主要的Web浏览器都实现了该规范。它可以解析HTML文档的几乎所有元素,将其分解为不同的标记和片段,可以针对各种用例将其过滤掉。它以与主要浏览器相同的方式解析文本。它还可以处理损坏的HTML标记并添加一些必要的标记以完成结构。它也是用纯python代码编写的。
lxml也是一个类似的解析器,但是由XML特性驱动,而不是由HTML驱动。它依赖于外部C库。与html5lib相比,它更快。
让我们通过一个样本标签示例观察这两个解析器在行为上的差异,并查看输出。
示例
from bs4 import BeautifulSoup
html5_structure = BeautifulSoup("<head><li></p>", "html5lib")
print(html5_structure)
lxml_structure = BeautifulSoup("<head><li></p>", "lxml")
print(lxml_structure)运行上面的代码给我们以下结果
输出结果
<html><head></head><body><li><p></p></li></body></html> <html><head></head><body><li></li></body></html>
如我们所见,html5lib通过合并
标签。lxml库更侧重于类似xml的结构,并且完全忽略了标记。
热门推荐
10 对患者生日祝福语简短
11 结婚祝福语简短装备
12 周岁祝福语学生文案简短
13 订婚领证祝福语简短精辟
14 导师获奖祝福语大全简短
15 新婚购房祝福语简短精辟
16 牛年祝福语简短的爱人
17 送芒果的祝福语简短
18 送给学长毕业祝福语简短