Scrapy豆瓣爬虫

scrapy安装以及简单使用

  • 1.进入终端,输入命令pip install scrapy 安装模块。安装成功后,新建一个项目,输入命令scrapy startproject douban ,这样就能看到一个douban文件夹,目录结构如下:

    介绍下各个文件的作用
    scrapy.cfg:项目的配置文件
    douban/items.py:项目的items文件
    douban/pipelines.py:项目的pipelines文件
    douban/settings.py:项目的设置文件
    douban/spiders/:存储爬虫的目录

明确在Item中需要爬取的数据

  • 1.抓取豆瓣电影的片名(movie_name)、导演(movie_director)、编剧(movie_writer)、演员(movie_actor)、上映日期(movie_date)、片长(movie_long)、电影描述(movie_description)。在scrapy中,Item是用来加载抓取内容的容器,类似于python中的字典。比如movie_name就像字典中的键,爬取到的数据就是字典中的值。


制作爬虫

  • 2.1 制作爬虫分成两步:先爬后取,首先获取网页的所有内容,然后取出对我们有用的部分。下面写一只爬虫,命名为DoubanSpider.py保存在douban\spiders目录下,代码如下:


    name是唯一的命名,运行scrapy crawl douban 这里的douban就是这个name,allow_domains 是搜索的域名范围,这里的start_urls 为空,在后面的函数会进行填充。

  • 2.2 很多情况下我们是直接在start_urls 中存入的页面url,但是这里我们爬取的链接有很多而且是有规律的。那么解释下start_requests 这个方法是干什么的:

   def start_requests(self):
          for url in self.start_urls:
                yield self.make_requests_from_url(url)  #可见是从start_urls中读取链接,使用make_requests_from_url生产Request
 可见`start_requests` 是系统默认调用的,我们可以重写这个函数,根据需求定制自己的start_urls。豆瓣电影的url是`http://movie.douban.com/subject_search?search_text=` +`电影名`。这里定制了请求头,不加请求头发现访问404错误
 ![](http://upload-images.jianshu.io/upload_images/4300291-53a53b5cbd377c38?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)
  • 2.3 parse函数,上面执行了请求,回调函数即为parser。scrapy帮助我们处理Request请求,会获得请求的url网站的响应response,我们重写parser函数:


    在这个函数中我们获得电影的url链接,使用的是xpath方法,同样也可以使用css方法,语法可以查询http://www.w3school.com这个网站。获得url后继续发送Request请求,回调函数是自定义的parse_movie函数。

  • 2.4 在回调函数parse_movie中我们真正抓取我们要的数据,这里进入的就是电影的具体界面,使用的仍然是xpath方法。作为一只爬虫,Spider希望将其抓取的数据存放到Item zhong ,这里定义了前面的DoubanItem对象,把爬取到的内容存入到该对象中。


    运行命令scrapy crawl douban 就能在终端看到打印出的数据

存储内容

  • 1.保存信息有4种方式:json,json lines,csv,xml。假如这里用json导出,命令如下:

     scrapy crawl douban -o items.json -t json
    
-o后面是导出文件名,-t后面是导出类型
- 2.当Item在Spider中被收集之后,将会被传递到Item Pipeline,一些组件会按照一定的顺序执行对Item处理。我们要编写自己的item pipeline,每个item pipeline都是个独立的python类,必须实现process_item(self, item, spider)方法。
* item(Item对象) - 被爬取的item
* spider(Spider对象) -爬取该item的spider
![](http://upload-images.jianshu.io/upload_images/4300291-db26008b29c8f8af?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)

    将所有的item存储到items.json文件中,每行包含一个序列化为json格式的item,且参数ensure_ascii=False解决了json格式的中文编码问题。
- 3.启动一个Item Pipeline 组件,你必须将它的类添加到 ITEM_PIPELINES 配置,修改settings.py配置文件,加入如下,:
![](http://upload-images.jianshu.io/upload_images/4300291-93b9d42ad74b9558?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)

 按照工程名.pipelines.自定义pipeline组建类名格式编写,后面的数字通常定义在0-1000之间。

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

推荐阅读更多精彩内容