scrapy(一)建立一个scrapy项目

本项目实现了获取stack overflow问题,使用python语言,scrapy框架,选取mongoDB作为持久化数据库,redis做为数据缓存

项目源码可以参考我的github:https://github.com/corolcorona/StacksSpider

 

1.创建一个scrapy项目

在创建的目录下执行命令:scrapy startproject 项目名

这样就创建好了一个名为stackspider的项目, 创建成功后,项目会产生以下文件

 

常用到的:

  • settings.py 爬虫相关的配置信息,数据库配置等
  • items.py    定义数据格式,可以用来保存爬取得数据,类似于python的字典
  • pipelines    数据持久化,处理items保存的数据
  • spiders       爬虫目录,写具体的爬虫可以在此文件夹下增加python文件

 

2.使用scrapy

创建完成后已有提示,所以我们创建一个用于抓取网站的文件名为stack

我们可以通过scrapy crawl 爬虫的name 来进行运行

但是这样会报错Crawled (403) <GET > (referer: None)或者Crawled (200) <GET > (referer: None)

原因是网站的反爬虫策略,所以我们可以

1.设置代理进行执行在命令上加上-s USER_AGENT='Mozilla/5.0'

2.修改scrapy的user-agent默认值

通过第一种方法我们可以获取到网页的html

项目就搭建好了

 

转载于:https://www.cnblogs.com/corolcorona/p/6801960.html

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值