python的scrapy框架的安装_Python之Scrapy爬虫框架安装及简单使用

题记:早已听闻python爬虫框架的大名。近些天学习了下其中的Scrapy爬虫框架,将自己理解的跟大家分享。有表述不当之处,望大神们斧正。

一、初窥Scrapy

Scrapy是一个为了爬取网站数据,提取结构性数据而编写的应用框架。 可以应用在包括数据挖掘,信息处理或存储历史数据等一系列的程序中。

其最初是为了 页面抓取 (更确切来说, 网络抓取 )所设计的, 也可以应用在获取API所返回的数据(例如 Amazon Associates Web Services ) 或者通用的网络爬虫。

本文档将通过介绍Scrapy背后的概念使您对其工作原理有所了解, 并确定Scrapy是否是您所需要的。

当您准备好开始您的项目后,您可以参考 入门教程 。

二、Scrapy安装介绍

Scrapy框架运行平台及相关辅助工具

Python 2.7(Python最新版3.5,这里选择了2.7版本)

Python Package: pip and setuptools. 现在 pip 依赖 setuptools ,如果未安装,则会自动安装setuptools 。

lxml. 大多数Linux发行版自带了lxml。如果缺失,请查看http://lxml.de/installation.html

OpenSSL. 除了Windows(请查看 平台安装指南)之外的系统都已经提供。

您可以使用pip来安装Scrapy(推荐使用pip来安装Python package).

pip install Scrapy

Windows下安装流程:

1、安装Python 2.7之后,您需要修改 PATH 环境变量,将Python的可执行程序及额外的脚本添加到系统路径中。将以下路径添加到 PATH 中:

C:\Python27\;C:\Python27\Scripts\;

除此之外,还可以用cmd命令来设置Path:

c:\python27\python.exe c:\python27\tools\scripts\win_add2path.py

安装配置完成之后,可以执行命令python --version查看安装的python版本。(如图所示)

293230-20161013164907296-1426174352.png

请确认下载符合您系统的版本(win32或者amd64)

3、打开命令行窗口,确认 pip 被正确安装:

pip --version

4、到目前为止Python 2.7 及 pip 已经可以正确运行了。接下来安装Scrapy:

pip install Scrapy

至此windows下Scrapy安装已经结束。

三、Scrapy入门教程

1、在cmd中创建Scrapy项目工程。

scrapy startproject tutorial

copycode.gif

H:\python\scrapyDemo>scrapy startproject tutorial

New Scrapy project 'tutorial', using template directory 'f:\\python27\\lib\\site-packages\\scrapy\\templates\\project', created in:

H:\python\scrapyDemo\tutorial

You can start your first spider with:

cd tutorial

scrapy genspider example example.com

copycode.gif

2、文件目录结构如下:

293230-20161013170807140-1062330623.png

解析scrapy框架结构:

scrapy.cfg: 项目的配置文件。

tutorial/: 该项目的python模块。之后您将在此加入代码。

tutorial/items.py: 项目中的item文件。

tutorial/pipelines.py: 项目中的pipelines文件。

tutorial/settings.py: 项目的设置文件。

tutorial/spiders/: 放置spider代码的目录。

3、编写简单的爬虫

1、在item.py中配置需采集页面的字段实例。

copycode.gif

1 # -*- coding: utf-8 -*-

2

3 # Define here the models for your scraped items

4 #

5 # See documentation in:

6 # http://doc.scrapy.org/en/latest/topics/items.html

7

8 import scrapy

9 from scrapy.item import Item, Field

10

11 class TutorialItem(Item):

12 title = Field()

13 author = Field()

14 releasedate = Field()

copycode.gif

2、在tutorial/spiders/spider.py中书写要采集的网站以及分别采集各字段。

copycode.gif

1 # -*-coding:utf-8-*-

2 import sys

3 from scrapy.linkextractors.sgml import SgmlLinkExtractor

4 from scrapy.spiders import CrawlSpider, Rule

5 from tutorial.items import TutorialItem

6

7 reload(sys)

8 sys.setdefaultencoding("utf-8")

9

10

11 class ListSpider(CrawlSpider):

12 # 爬虫名称

13 name = "tutorial"

14 # 设置下载延时

15 download_delay = 1

16 # 允许域名

17 allowed_domains = ["news.cnblogs.com"]

18 # 开始URL

19 start_urls = [

20 "https://news.cnblogs.com"

21 ]

22 # 爬取规则,不带callback表示向该类url递归爬取

23 rules = (

24 Rule(SgmlLinkExtractor(allow=(r'https://news.cnblogs.com/n/page/\d',))),

25 Rule(SgmlLinkExtractor(allow=(r'https://news.cnblogs.com/n/\d+',)), callback='parse_content'),

26 )

27

28 # 解析内容函数

29 def parse_content(self, response):

30 item = TutorialItem()

31

32 # 当前URL

33 title = response.selector.xpath('//div[@id="news_title"]')[0].extract().decode('utf-8')

34 item['title'] = title

35

36 author = response.selector.xpath('//div[@id="news_info"]/span/a/text()')[0].extract().decode('utf-8')

37 item['author'] = author

38

39 releasedate = response.selector.xpath('//div[@id="news_info"]/span[@class="time"]/text()')[0].extract().decode(

40 'utf-8')

41 item['releasedate'] = releasedate

42

43 yield item

copycode.gif

3、在tutorial/pipelines.py管道中保存数据。

copycode.gif

1 # -*- coding: utf-8 -*-

2

3 # Define your item pipelines here

4 #

5 # Don't forget to add your pipeline to the ITEM_PIPELINES setting

6 # See: http://doc.scrapy.org/en/latest/topics/item-pipeline.html

7 import json

8 import codecs

9

10

11 class TutorialPipeline(object):

12 def __init__(self):

13 self.file = codecs.open('data.json', mode='wb', encoding='utf-8')#数据存储到data.json

14

15 def process_item(self, item, spider):

16 line = json.dumps(dict(item)) + "\n"

17 self.file.write(line.decode("unicode_escape"))

18

19 return item

copycode.gif

4、tutorial/settings.py中配置执行环境。

copycode.gif

1 # -*- coding: utf-8 -*-

2

3 BOT_NAME = 'tutorial'

4

5 SPIDER_MODULES = ['tutorial.spiders']

6 NEWSPIDER_MODULE = 'tutorial.spiders'

7

8 # 禁止cookies,防止被ban

9 COOKIES_ENABLED = False

10 COOKIES_ENABLES = False

11

12 # 设置Pipeline,此处实现数据写入文件

13 ITEM_PIPELINES = {

14 'tutorial.pipelines.TutorialPipeline': 300

15 }

16

17 # 设置爬虫爬取的最大深度

18 DEPTH_LIMIT = 100

copycode.gif

5、新建main文件执行爬虫代码。

1 from scrapy import cmdline

2 cmdline.execute("scrapy crawl tutorial".split())

最终,执行main.py后在data.json文件中获取到采集结果的json数据。

293230-20161024173539734-1976969002.png

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值