BeautifulSoup中各种html解析器的比較及使用

本文对比了BeautifulSoup支持的各种HTML解析器,包括Python标准库、lxml和html5lib等,并详细介绍了它们的优缺点及安装方法。

Beautiful Soup解析器比較

·Beautiful Soup支持各种html解析器。包含python自带的标准库。还有其它的很多第三方库模块。

当中一个就是lxml parser,至于lxml parser的安装,能够通过下面方法安装:

1)easy_install lxml   2)pip install lxml    

另外。python对于模块的安装,能够查看博客说明。分为两种:easy_install pip.

第二种纯python解析器为html5lib解析器。能够像web浏览器那样解析html页面,你能够通过以下两种方式安装html5lib

1)easy_install html5lib   2)pip install html5lib

以下对各种html解析器的优缺点做一下对照:


解析器用法长处缺点
Python’s html.parserBeautifulSoup(markup,"html.parser")
  • python自身带有
  • 速度比較快
  • 能较好兼容 (as of Python 2.7.3 and 3.2.)
不能非常好地兼容(before Python 2.7.3 or 3.2.2)
lxml’s HTML parserBeautifulSoup(markup,"lxml")
  • 速度非常快
  • 兼容性好
External C dependency
lxml’s XML parserBeautifulSoup(markup, "lxml-xml") BeautifulSoup(markup,"xml")   速度非常快
  • The only currently supported XML parser
External C dependency
html5libBeautifulSoup(markup, "html5lib")1)兼容性非常好
2)能够像web浏览器一样解析html页面
3) Creates valid HTML5
  • 速度非常慢
  • External Python dependency

假设你想追求速度的话。建议使用 lxml,假设你使用的python版本号2.x是2.7.3之前的版本号,或者python3.x的是3.2.2之前的版本号。你非常有必要安装使用 html5lib或lxml使用。由于python内建的html解析器不能非常好地适应于这些老版本号。



转载于:https://www.cnblogs.com/wzzkaifa/p/7111431.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值