python数据分析前奏:中国教育近30年来官方所有的通知政策文件大数据的爬取与下载

一、概述

一般情况下,一套完整的数据分析的主要过程是:

  1. 需求分析
  2. 数据获取
  3. 数据清洗
  4. 数据分析的逻辑构建
  5. 可视化
  6. 报告撰写
  7. 总结反思

很多时间,公司的数据是从网站后台直接导出给数据分析师。但是在某些情况下,数据并不能从后台直接获取,或者只能从别的公司的网站获取,这时候数据分析师不光需要掌握数据分析的逻辑,还需要掌握一定的数据获取能力,最便捷的数据获取方式就是python爬虫。
本文内容:
本文主要爬取并下载教育部从1981年至今发布的所有通知、公告、政策文件,进而通过数据分析来呈现中国近30年的教育发展及未来走向。

二、运行环境

  • python3.7
  • win10或mac
  • pycharm (一款好用的IDE)
  • 所需要的python库:
    (1) requests: python中较为基础的爬虫库,多数情况用于获取网页信息,具体学习移步:
    requests官方教程
    (2) PyQuery:一个好用的解析库,用来定位你所需要的信息在网页中的位置。具体学习移步:
    PyQuery官方教程
    (3) pandas:python数据分析中最常用的库,功能异常强大。
    具体学习移步:
    pandas官方教程
    (4) json:读取json文件的库(python默认已安装)
    (5) xlwt:读取excel文件的库(读取excel报库缺失错误时手动安装)
    具体的安装直接在cmd或者终端中输入:
    pip(或pip3) install 库命,例如
    pip install requests
    注:也可以直接使用现成的一些python爬虫轮子,例如强大的Scrapy(本文不做介绍)

三、爬虫过程

1. 在程序中导入所需的库:

import requests   # 导入requests
from pyquery import PyQuery as pq   # 导入PyQuery
import time
import pandas as pd
import json
import xlwt

2. 构造爬虫的headers

顾名思义,就是一些爬虫的伪装,需要向浏览器提交的数据等,统一放入headers中。
User-Agent 后面是跟的浏览器的伪装,由于服务器一般拒绝爬虫爬取,因为会造成服务器压力,因此一般都需要伪装

headers = {
    'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/73.0.3683.103 Safari/537.36'
}

3. 一些变量赋值,如网站的地址,输出文件的名字

url_base1 = 'http://www.moe.gov.cn/was5/web/search?channelid=258518&searchword=&page='
# 网站的部分ID地址,page=的后面是页码的数,在之后的循环中使用
file_name = 'Policy.cvs'

4. 爬虫逻辑及网站预分析

在Chrome浏览器打开地址:
http://www.moe.gov.cn/was5/web/search?channelid=258518&searchword=&page=1
右键 “检查” ,如图:

源网页代码.png

需要爬取并下载的内容:
(1)文章标题
(2)发布时间
检查源代码发现一些标题由于过长而只显示了部分,后面是...,这就需要进入二级的网站,再从二级网站获取标题。如图
二级网页.png

有了这些,那么具体的爬虫过程也就很清楚了:
(1)首先,进入第一页
(2)获取一个标题的链接与时间,时间直接存储,用链接打开二级网站
(3)在二级网站获取标题
(4)重复(2)(3),直到这一页中的题目与时间全部存储完毕
(5)转入第二页
(6)重复(2)(3)(4)遍历这一页中的题目与时间
(7)转入第三页.......之后就是程序的循环了

5. 具体代码爬取过程

  • 定义爬取一页的函数以便在后续程序中调用
def get_one_page(url):
    try:
        response = requests.get(url, headers=headers)   # 用requests获取网站代码
        response.encoding = response.apparent_encoding 
        #提前设置encoding,避免后续解析乱码问题
        content = response.text   
        # 将获取的代码内容,也就是text属性直接给content
        print('进入页面成功')
        doc = pq(content)   
        # 将网页文字代码,也就是content赋值给doc,其类型为PyQuery
        for item in doc('.gongkai_wenjian ul li').items():   
        # 定位要爬取题目的超链接
            date = item('span').text()
            # 获取发文日期
            response_title = requests.get(item('a').attr('href'),headers=headers)
            # 重新用requests库打开这个超链接并获取网页代码
            response_title.encoding = response_title.apparent_encoding
            content_title = response_title.text
            doc_title = pq(content_title)
            title = doc_title('h1').text().replace('\n','')
            # 定位二级网站标题位置并返回给title
            Policy = (
                item('a').attr('href'),
                title,
                date
            )
            # 定义一个元组,包含链接、题目与日期
            print(Policy)
            write_to_file(Policy)
            # 用write_to_file()函数将其存储起来,后面进行函数定义
    except Exception as e:
        print('Error', e.args)
  • 定义write_to_file()函数,补上上一个函数的坑
def write_to_file(content):
    with open(file_name, 'a', encoding='utf-8') as f:
       f.write(content[0]+','+content[1]+','+content[2]+'\n')
# 存储为.cvs文件,之后再输出为excel
  • 定义一个输出excel文件的函数:
def creat_excel(file_name):
    df = pd.DataFrame(pd.read_csv(file_name, encoding='utf-8', names=['Url', 'Title','date']))
    df.drop_duplicates(subset='Url', keep='last', inplace=True)
  # 舍去重复的标题,保留最后一个
    df.to_excel('Policy_qingdao.xlsx')
  • 有了以上三个函数,就可以定义主函数了:
def main():
    for i in range(1,680):
    # 获取1到680页的内容。(如果网站有更新页码此项也要更新)
        print('即将爬取第'+str(i)+'页')
        url = url_base1 + str(i)
        get_one_page(url)
        time.sleep(0.1)  # 爬取一页休眠0.1秒
    creat_excel(file_name)
    # 输出excel
  • 定义了主函数,还需要执行:
if __name__ == '__main__':
    main()

至此,程序代码已完整,直接运行,过10分钟左右就可以获取1万多条信息存在excel中。
下一篇文章将具体分析这一万多条大数据;在正式开始之前,读者可以阅读一些基础知识。数据分析环境搭设以及关于excel文件的读取与分析可以参考之前的一篇文章:Python 数据分析实例:
Pandas分析问卷选择率

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,142评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,298评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 162,068评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,081评论 1 291
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,099评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,071评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,990评论 3 417
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,832评论 0 273
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,274评论 1 310
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,488评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,649评论 1 347
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,378评论 5 343
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,979评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,625评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,796评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,643评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,545评论 2 352

推荐阅读更多精彩内容