1.环境搭建

2.选择需要的.whl文件下载,一般选择最后的,感觉意思是最近更新的包,以下是.whl文件下载链接地址:

http://www.lfd.uci.edu/~gohlke/pythonlibs/

1.python:表示包文件。

2.whl 格式:这是一个压缩包,在其中包含了py文件,以及经过编译的pyd文件。

这个格式可以使文件在不具备编译环境的情况下,选择合适自己的python环境进行安装。

 

安装方法如下

进入命令行输入:pip install xxxx.whl

升级方法如下

进入命令行输入:pip install -U xxxx.whl

因为这个Scarpy是依赖这个Twised这个的  所以可以安装这个whl  文件  Scarpy依赖环境

E:\Develop\Scripts  这个目录下  cmd  pip install 安装

还有一种方法是安装  visualcppbuildtools_full   不过这个安装可能有点久

pip install scrapy

然后找到相应的 whl  Twised.whl  安装就好了   去到对应的路径安装

2.基本使用

因为不同于Django,flask  新建项目有选择的  所以我们只能通过命令来创建

scrapy startproject first-scrapy

创建一个爬虫   scrapy genspider 爬虫名 爬虫的地址  baidu  baidu.com

  • name: 它定义了蜘蛛的唯一名称

  • allowed_domains: 它包含了蜘蛛抓取的基本URL;(只认定这个域名)

  • start-urls: 蜘蛛开始爬行的URL列表;

  • parse(): 这是提取并解析刮下数据的方法;

运行爬虫  scrapy crawl 爬虫名

3.数据提取

第一步一定要记得修改User-Agent

不加这个  .extract返回一个unicode字符创      Selector返回的是选择器  为什么会返回的是选择器呢?这样还可以继续Xpath筛选

利用框架如何快速的爬取资料:先创建scrapy项目    设置请求头User-Agent  设置url

利用Scrapy自带的Xpath选择器筛选  输出即可  这是最简单的  输出到控制台

既然可以输出到控制台那么其实保存都文件也容易

json.cn

.csv  是一种表格的形式  可以用excel打开

在哪了提取这些数据  在response啊   可以直接

scrapy crawl zhongheng -o book.json

4.如何推送到 pipeline 

通过yield

然后item接受

打印item  但是和在spider中的输入输出不一样呀  并没有打印这个item 没有白色的日志

在setting中打开ITEM_PIPELINES  他是一个字典,前面是item_pipeline路径,数字表示优先级

“w”会覆盖以前的信息  “a”会追加

有一个问题是:文件会重复开启 如何让文件只开启一次呢

这就是利用pipeline保存我们数据的问题

在item模板中 无论什么数据类型

都可以用 scrapy fielter

这回推送的Item中的类对象 还是通过yield推送  所以还要记得转字典,也要记得转字符串

6.Scrapy 的细节

可以爬取 不同的网页,不同类型的网页,只需要写一个spider就好了。

但是我要怎么处理筛选呢? 通过response的url来判断  这是广度爬取

还有一个深度  一种爬虫方式。就是先遍历完左边的再慢慢的推到右边

小说练习

1.第一种找url规律的方法  看是否递增啥的

2.将所有的url都拿出来  挨个去访问

有一个叫文件流的东西,就是当只有内存的满了才会存到文件中

那怎么让它实时的存储呢  那就要用flush了

访问的间隔 download_delay = 3

第一部分完了

  大概的知道这个框架的运行流程了,也知道怎么用xpath了也可以连续的

爬取了,如何推送,如何的保存这些数据。这应该是小的一部分吧

在继承与CrawlSpider中  restrict  提取到那个标签就可以了

创建新的spider  用 -t  crawl  选择使用这个模板

copy  xpath  这么使用吗

 

2019.04.23 Scrapy框架的更多相关文章

  1. Python 爬取 北京市政府首都之窗信件列表-[Scrapy框架](2020年寒假小目标04)

    日期:2020.01.22 博客期:130 星期三 [代码说明,如果要使用此页代码,必须在本博客页面评论区给予说明] //博客总体说明 1.准备工作(本期博客) 2.爬取工作 3.数据处理 4.信息展 ...

  2. Scrapy爬虫框架(实战篇)【Scrapy框架对接Splash抓取javaScript动态渲染页面】

    (1).前言 动态页面:HTML文档中的部分是由客户端运行JS脚本生成的,即服务器生成部分HTML文档内容,其余的再由客户端生成 静态页面:整个HTML文档是在服务器端生成的,即服务器生成好了,再发送 ...

  3. 学习scrapy框架爬小说

    一.背景:近期学习python爬虫技术,感觉挺有趣.由于手动自制爬虫感觉效率低,了解到爬虫界有先进的工具可用,尝试学学scrapy爬虫框架的使用. 二.环境:centos7,python3.7,scr ...

  4. Python爬虫Scrapy框架入门(2)

    本文是跟着大神博客,尝试从网站上爬一堆东西,一堆你懂得的东西 附上原创链接: http://www.cnblogs.com/qiyeboy/p/5428240.html 基本思路是,查看网页元素,填写 ...

  5. Python使用Scrapy框架爬取数据存入CSV文件(Python爬虫实战4)

    1. Scrapy框架 Scrapy是python下实现爬虫功能的框架,能够将数据解析.数据处理.数据存储合为一体功能的爬虫框架. 2. Scrapy安装 1. 安装依赖包 yum install g ...

  6. 爬虫基础(五)-----scrapy框架简介

    ---------------------------------------------------摆脱穷人思维 <五> :拓展自己的视野,适当做一些眼前''无用''的事情,防止进入只关 ...

  7. Scrapy 框架简介

    Scrapy 框架 介绍 Scrapy一个开源和协作的框架,其最初是为了页面抓取 (更确切来说, 网络抓取 )所设计的,使用它可以以快速.简单.可扩展的方式从网站中提取所需的数据.但目前Scrapy的 ...

  8. [Python][Scrapy 框架] Python3 Scrapy的安装

    1.方法(只介绍 pip 方式安装) PS.不清楚 pip(easy_install) 可以百度或留言. cmd命令: (直接可以 pip,而不用跳转到 pip.exe目录下,是因为把所在目录加入 P ...

  9. 解读Scrapy框架

    Scrapy框架基础:Twsited Scrapy内部基于事件循环的机制实现爬虫的并发.原来: url_list = ['http://www.baidu.com','http://www.baidu ...

随机推荐

  1. 论文阅读笔记四十三:DeeperLab: Single-Shot Image Parser(CVPR2019)

    论文原址:https://arxiv.org/abs/1902.05093 github:https://github.com/lingtengqiu/Deeperlab-pytorch 摘要 本文提 ...

  2. Gradle sync failed: SSL peer shut down incorrectly

    http://www.th7.cn/Program/Android/201604/817127.shtml 问题是在更新版本后出现的,被墙隔断的原因 引自大神解决方案 这个问题通常出现在Android ...

  3. php实现微信企业向用户付款

    <?php header('content-type:text/html;charset=utf-8'); $data['mch_appid']='##################';//商 ...

  4. CSS3标准盒模型还是IE怪异模型box-sizing属性的应用设置

    在一个文档中,每个元素都被表示为一个矩形的盒子.盒子模型具有4个属性['外边距(margin)','边框(border)','内边距(padding)','内容(content)']. 我们要设置某个 ...

  5. 开放接口/RESTful/Api服务的设计和安全方案详解

    一.总体思路 这个涉及到两个方面问题:一个是接口访问认证问题,主要解决谁可以使用接口(用户登录验证.来路验证)一个是数据数据传输安全,主要解决接口数据被监听(HTTPS安全传输.敏感内容加密.数字签名 ...

  6. Java _类 相关知识

    成员变量 java对象的属性就是成员变量,其实成员变量就是指普通的变量,可以设置初始值,也可以不设置.当不设置时,会被设置为默认值.(当成员变量前面有private关键词时,说明定义了一个私有成员) ...

  7. 删除倒数第k个元素

    给定一个链表,删除链表的倒数第 n 个节点,并且返回链表的头结点. 示例: 给定一个链表: 1->2->3->4->5, 和 n = 2. 当删除了倒数第二个节点后,链表变为 ...

  8. 一些有用的huginn Agent

    具体API地址 https://huginnio.herokuapp.com/agents 貌似这些Agent都可以按照频率和定时的时间点来触发, 1.Attribute Difference Age ...

  9. 置信区间-显著性-P-值

    1.置信区间:误差范围(区间)在统计概率中就叫做置信区间:简单来说置信区间就是误差范围 我们用中括号[a,b]表示样本估计总体平均值的误差范围的区间,由于a和b的确切数值取决于你希望自己对于“该区间包 ...

  10. MySQL错误码

    MySQL运行异常时,查看服务日志可看到error number,该错误码为系统调用出错码,具体如下. errno.00 is: Success    成功 errno.01 is: Operatio ...