文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

Python 网络抓取和文本挖掘-1 H

2023-01-31 01:54

关注

偶然在图书馆看到《基于R语言的自动数据收集:网络抓取和文本挖掘实用指南》,被第一章概述所吸引,迫不及待地借回来,下载代码在RStuido里进行实验。然后断断续续,囫囵吞枣式地翻了一遍,增长了知识,但没有如预期提升技能。决定换一种方式,照着书里的内容,用Python实现一遍,作为读书笔记。 结果第一章就遇到困难了,要实现第一章的例子需安装basemap、geos等一系列包,还要实现对表格数据的提取。那就从第二章开始吧,直到第八章,然后再回过头来完成第一章的例子。

1. HTML

     1) HTML一个纯文本文件。

     2) HTML的标记能够定义文档的某些部分为标题、某些部分为链接、某些部分为表格,还有其它多种形式。

     3) 标记定义依赖于预先定义好的字符序列(即标签,如<html> 、<head>等)来封装文本部分。

     4) 用浏览器打开一个html文件,看到的是浏览器对这个hrml文件的解释和展现。

     5) 起始标签(如<title>)、内容和终止标签(如</title>)组合起来称为元素。

<title>First HTML</title>
     6) HTML文件是一个树形结构。


2. HTMLParser

HTMLParser是python 自带的一个解析html的类,通过重载它的方法,解析出所需要的数据。查看帮助文档:https://docs.python.org/2/library/htmlparser.html

直接拷贝帮助文档的例子稍作修改,就可以用作提取数据。

    1)常用的属性属性:lasttag  

    2) 常用的可重载的方法:

         handle_starttag(self, tag, attrs):
         handle_endtag(self, tag):
         handle_data(self, data):
         handle_comment(self, data):

    3)实例

      从 http://www.r-datacollection.com/materials/html/fortunes.html 网页中提取用<i>标签标记的内容 

      只要了解了urllib2和HTMLParser的使用,实现很简单,在MyHTMLParser类中定义了一个属性 data存放读取到的数据。源码如下:

# -*- coding:utf-8 -*-
import urllib2
from HTMLParser import HTMLParser


class MyHTMLParser(HTMLParser):

    def __init__(self):
        HTMLParser.__init__(self)
        self.data = []

    def get_data(self):
        return self.data

    def handle_data(self, data):
        if self.lasttag == 'i':
            if data != None and len(data.strip()) > 0:
                s = data.strip("'")
                self.data.append(s)


def get_html(url = 'http://www.r-datacollection.com/materials/html/fortunes.html'):
    request = urllib2.Request(url)
    response = urllib2.urlopen(request)
    page = response.read()
    parser = MyHTMLParser()
    parser.feed(page)
    parser.close()
    for line in parser.get_data():
        print line


if __name__ == '__main__':
    get_html()

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯