码迷,mamicode.com
首页 > 编程语言 > 详细

Python 开发轻量级爬虫06

时间:2016-09-05 09:05:29      阅读:221      评论:0      收藏:0      [点我收藏+]

标签:

Python 开发轻量级爬虫

(imooc总结06--网页解析器)

介绍网页解析器
    将互联网的网页获取到本地以后,我们需要对它们进行解析才能够提取出我们需要的内容。
    也就是说网页解析器是从网页中提取有价值数据的一种工具,对于搜索引擎来说它会提取出网页所有的url,用于后续的访问。
    但是,对于我们定向爬虫来说,除了提取出待爬取的url之外,会提取出我们感兴趣的想要的有价值的数据。
    也就是说,网页解析器会以下载好的HTML网页字符串作为输入,然后提取出有价值的数据和新的待爬取的url列表。

Python有哪几种网页解析器呢?
    最直观的一种使用正则表达式,它会将整个网页当做一个字符串,然后使用模糊匹配方式来提取出有价值数据。
    虽然直观,但是文档要是比较复杂的话,这种方式非常的麻烦。

    我们可以使用python自带的html.parser来解析网页。
    可以使用BeautifulSoup这个第三方插件来解析网页。
    可以使用lxml这个第三方的插件来解析html网页或xml网页。
    其中BeautifulSoup这个第三方插件,它可以使用python自带的html.Parser作为它的解析器,也可以用lxml作为它的解析器,相对来说比较强大。
    这里使用BeautifulSoup来解析网页。

    其中正则表达式是一种字符串型的模糊匹配,另外三种是结构化的解析。
    什么是结构化的解析呢?
    是将整个网页文档下载成一个DOM(document object model)树,
    也就是document object model文档对象模型这么一棵树,以树的形式来进行元素的上下级遍历和访问的。

技术分享

    DOM树是W3C官方定义的访问解析html的标准接口。
    它会将整个网页的文档当成document对象,在它的下面就是html根节点,再下面就是head元素和body元素,head元素下面又会包含titile元素每个元素。
    如果没有子元素,就会对应文本,比如说文本“我的标题”,Body元素下也会包含很多的子元素 a元素 div元素,a元素下包含需要文本链接文本 Div元素 包含段落文本。
    同时每个元素有自身属性的话,herf就是链接元素它指定的url。
    如何使用这种方式?
    dom就将整个文档下载成树型结构,使用树型的上下级关系,可以很方便的定位到某个元素,然后访问这个元素的自身的属性、文本。
    BeautifulSoup这个第三方的插件就是使用dom的方式来解析网页的。

Python 开发轻量级爬虫06

标签:

原文地址:http://www.cnblogs.com/billyzh/p/5841017.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!