python爬虫框架-Scrapy安装详细教程

首先说明一下,我这里讲的是Windows64/32位操作系统下的安装教程。其他linux、Ubuntu环境下的安装暂时还未整理。请自行寻找教程。

安装Scrapy主要分为一下九个步骤:
1. 安装python。(相信大家都已经安装好了)
2. 配置python环境变量。(怕大家没有配置,所以这里啰嗦一下)
3. 下载安装pywin32。
4. 下载安装pip和setuptools。(为方便后续使用pip安装scrapy)
5. 安装Twisted。
6. 安装Zope.Interface和pyOpenSSL。
7. 安装lxml。
8. 下载 Microsoft Visual C++库:VCForPython27.msi。
9. 安装scrapy.

接下来我们就来详细讲解每一步。

1.安装python。

2.配置环境变量

  • 将python的安装目录复制到环境变量。右击“我的电脑”-“属性”-“高级系统设置”-“高级”-“环境变量”,找到“系统变量”里的path,然后将
    C:\Python27\;C:\Python27\Scripts;这两个路径添加到后面。
  • 验证python是否安装成功。打开cmd,输入python,
    这里写图片描述
    若没有报错,则安装成功。
  • 报错则说明你的环境变量加错了。请重新检查。

3.安装pywin32。

4.安装pip和setuptools。

验证安装成功:

这里写图片描述

  • pip是依赖于setuptools的,安装pip时会自动安装setuptools,所以这里就不赘述了。

5.安装Twisted。

注意:这里Twisted要安装对应版本,Twisted-13.1.0
进入python目录,输入命令

pip install twisted==13.1.0

这里写图片描述

6.安装Zope.Interface和pyOpenSSL

1.Zope.Interface下载地址:
https://pypi.python.org/pypi/zope.interface#downloads
2.pyOpenSSL下载地址:
https://pypi.python.org/pypi/pyOpenSSL#downloads

选择对应python版本的.egg包进行下载。如果你的Python版本和我的一样是2.7的,那这里有我下载好的两个包,直接去拿:

http://download.csdn.net/detail/mtbaby/9898934

3.这时候把这两个.egg文件拷贝进入python根目录下的scripts目录,同easy_installs等文件一个目录位置。然后进入cmd模式,在cmd模式下进入这个script目录,执行easy_install.py egg文件名,执行安装这个egg文件。

如图:

这里写图片描述

安装完以后进行验证:

这里写图片描述

没有报错说明安装成功。

7.安装lxml

lxml是一种使用 Python 编写的库,可以迅速、灵活地处理 XML

直接执行如下命令

pip install lxml

就可完成安装,如果提示 Microsoft Visual C++库没安装,则看步骤8.

8.下载 Microsoft Visual C++库:VCForPython27.msi

下载地址:https://www.microsoft.com/en-us/download/details.aspx?id=44266

下载后双击运行即可。

9.安装Scrapy

最后就是激动人心的时刻啦,上面的铺垫做好了,我们终于可以享受到胜利的果实啦!

进入python下的lib目录,执行如下命令


pip install Scrapy

这里写图片描述

安装完后验证:

这里写图片描述

如果提示如下命令,就证明安装成功啦,如果失败了,请检查上述步骤有何疏漏。

安装报错

别看我文章写的安装那么顺利,其实在安装的时候踩了不少坑,下面我就来说说:

1.步骤5,在安装Twisted的时候,我是下载Twisted的版本是Twisted 11.1,结果下载后安装完,进行步骤9的时候,提示

……
Requirement already satisfied: Twisted>=13.1.0 in /usr/lib64/python2.7/site-packages (from Scrapy)
……
TLSVersion.TLSv1_1: SSL.OP_NO_TLSv1_1,
AttributeError: ‘module’ object has no attribute ‘OP_NO_TLSv1_1’

网上查了一下,结果是Twisted 的版本不对,需要下载13.1版本的,
这里附上地址https://twistedmatrix.com/Releases/Twisted/13.1/

真的是,内心一万个***在奔腾。好吧,就就用命令下载

pip install twisted==13.1.0

这样就好了。

2.其他的报错我没记住啊,大家遇到了以后要和我分享啊。

  • 13
    点赞
  • 42
    收藏
    觉得还不错? 一键收藏
  • 8
    评论
Scrapy是一个基于Python爬虫框架,它可以帮助我们快速高效地抓取网站数据。在这里,我将介绍Scrapy的基本用法,让您能够快速入门。 安装Scrapy ----------------------- 在安装Scrapy之前,我们需要先安装Python。然后,我们可以通过以下命令来安装Scrapy: ``` pip install scrapy ``` 创建Scrapy项目 ----------------------- 创建Scrapy项目的命令是: ``` scrapy startproject project_name ``` 这个命令将会在当前目录下创建一个名为project_name的文件夹,其中包含了Scrapy项目的基本结构。 编写Spider ----------------------- 在Scrapy中,Spider是用来定义爬取网站的规则的。我们可以通过以下命令来创建一个Spider: ``` scrapy genspider spider_name domain_name ``` 其中,spider_name是我们自己定义的Spider名称,domain_name是我们要抓取的网站域名。 接下来,我们需要在Spider中定义如何爬取网站。这里我们以爬取“http://quotes.toscrape.com/”网站上的名言警句为例。我们可以在Spider中定义如下规则: ```python import scrapy class QuotesSpider(scrapy.Spider): name = "quotes" start_urls = [ 'http://quotes.toscrape.com/page/1/', 'http://quotes.toscrape.com/page/2/', ] def parse(self, response): for quote in response.css('div.quote'): yield { 'text': quote.css('span.text::text').get(), 'author': quote.css('span small::text').get(), 'tags': quote.css('div.tags a.tag::text').getall(), } next_page = response.css('li.next a::attr(href)').get() if next_page is not None: yield response.follow(next_page, self.parse) ``` 在上述代码中,我们首先定义了Spider的名称,接着定义了我们要爬取的起始URL,最后定义了如何解析网页的函数parse()。在parse()函数中,我们使用了Scrapy的选择器来提取网页中的名言警句,并将其保存到字典中。接着,我们使用response.follow()函数来获取下一页的URL,并继续解析。 运行Spider ----------------------- 要运行我们刚才创建的Spider,我们可以使用以下命令: ``` scrapy crawl spider_name ``` 其中,spider_name是我们之前创建的Spider名称。 Scrapy会自动去抓取我们定义的起始URL,并根据我们定义的规则来解析网页。解析完成后,Scrapy会将结果保存到我们指定的位置。 总结 ----------------------- Scrapy是一个非常强大的Python爬虫框架,它可以帮助我们快速高效地抓取网站数据。在本教程中,我们介绍了Scrapy项目的创建、Spider的定义以及如何运行Spider。如果您想更深入地学习Scrapy,可以参考官方文档:https://docs.scrapy.org/en/latest/。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值