Skip to content

Latest commit

 

History

History
153 lines (80 loc) · 6.22 KB

README.md

File metadata and controls

153 lines (80 loc) · 6.22 KB

Task:搜寻“不同标准的” 请自定义“最好用”,请记录搜索过程,以及搜索结果,以及你自己的分析结论


作业总结

必做:关于爬虫库和框架的报告如下;知乎回答已详细阅读,但是鉴于自己水平有限,大部分复现都有难度,先实现几个可以快速上手的爬虫,希望之后能尝试;

Challenge: 总共实现了四个小爬虫,后有介绍

这一周,阅读了大量博客和知乎问答(后有链接),同时分别尝试了用正则表达式、beautifulsoup、pyquery解析网页,之后尝试了scrapy和pyspider爬虫框架,精力有限,Nutch留到之后来了解;


Challenge: 总共实现了四个小爬虫

之前没有是编写过,重在体会过程!

1. 无框架爬取(静态、动态)

页面类型:豆瓣读书排行属于静态页面,十分易于爬取;

URL构造:针对多个页面,点击不同页面观察其url的变化,发现只有start部分变为一个新数字,通过推算,应该表示当前的项目序号!这样就可以构造url了

页面解析:分别使用正则表达式和beautifulsoup进行解析;具体逻辑请移步代码;

页面类型: 结论:Ajax动态加载; 浏览微博时,随着你不断向下滚动,新的内容会不断出现。如果我们以上一爬虫的抓取方法,抓取结果只有初始加载的几十行html代码,没有任何有用信息,显然有问题;

进入微博主页,选择开发者选项的network,限定只看XHR类型的URL,接着向下滑动,会发现不断有请求和返回产生,点击getindex?type……的项,就是最新的Ajax请求,点击Preview,就能看到返回的内容,点击Response能看到数据是以json格式组织的;

动态加载分析:

点击某一个XHR类URL,在Header中可以看到Request Header的各项内容,这样就很方便我们构造请求;通过观察不同请求的Header,可以发现随着下拉动态加载页面的Request URL中只有page选项在发生变化,其他都是固定的;这样就可以构造url了;

页面解析

这次解析尝试用pyquery,只要获得了response,用pyquery语法操作;

数据存储

数据保存到MongoDB中;

2、pyspider + phantomjs 抓取豆瓣图书排行

Handler文件

环境配置

Ubuntu 18.04 + PhantomJS-2.2.1 + MongoDB + PyMongo库 + 数据库可视化工具Robo 3Td-1.3

可能出现的问题: 1、 PhantomJS已在后台启动,会报错;

解决:杀死进程,重新启动;

(selenium提示它已经不支持phantom了啊,让用Chrome或Firefox……) 2、WebUI出现窗口很小的问题

解决: 需要修改debug.min.css 和debug.min.js两个文件,具体参考此github讨论: - 链接

操作流程

1、create新建项目,输入起始页url和项目名;

2、点击run单步调试进行首页爬取,右侧是调试界面;

3、点击web按钮,点击css功能,可以进行链接图形话界面选取;之后加入后侧代码;

4、定义翻页逻辑,找到next项url,使用callback()回调,实现下一页页面处理;

5、代码只需修改Handler类,逻辑和1.1相同;

6、运行,实时监控;

数据导出

运行结束后,可以直接到处为json或csv文件,本次直接导出为csv文件,保存在data文件中!

PS:

这个图形化操作方式真的很难用语言描述,还是建议大家上手尝试一下,真的很爽!相比于1.1节的抓取,图形化便捷很多!

目标网站:http://www.juzizhai.com/doc/mingyan/mingren/

环境配置

Ubuntu 18.04 + MongoDB + PyMongo 库

目的

重在走一遍基本过程,之后再尝试动态加载和浏览器模拟的内容;

1、创建项目;

2、创建Spider:

定义想要爬取的属性信息,

3、解析网页:

scrapy内嵌了css选择器,具体爬取规则可查看文档;主要点是后续request的衔接:找到”下一页”标签,callback构造循环;

4、对接数据结构:新建item实时保存 -可以抓取查看效果,再进行数据库保存

5、数据存储:scrapy可以在抓取时直接输出为各种格式数据:csv, json, pickle等或者可以直接ftp传输

6、数据库链接:使用Item Pipeline Item Pipeline的主要作用清洗 HTML 数据,验证爬取数据,检查爬取字段,查重并丢弃重复内容,将爬取结果储存到数据库;

在setting.py 中配置数据库信息;

7、执行抓取!

后记

一周的精力实在有限,各种东西只是初步感受了一下;

因为网站结构的时效性很强,所以网上很多爬虫教程即使很新,不少也会爆出各种Bug,心累……;

爬虫还是蛮有意思的(除了密密麻麻的前端代码),想要好好研究一下。

【参考文档】 Python有哪些常见的、好用的爬虫框架?

知乎回答: 开源爬虫框架各有什么优缺点?

开源爬虫Labin,Nutch,Neritrix介绍和对比

知乎:50种最棒的开源爬虫框架/项目

【待看优秀项目】

GitHub 上有哪些优秀的 Python 爬虫项目?

一个爬虫排名,不知道是否客观,待研究…… Top 50 open source web crawlers for data mining

爬虫的正当性

爬虫的合法性问题

友情提示:爬虫违法