1、创建项目

在开始爬取之前,您必须创建一个新的Scrapy项目。进入您打算存储代码的目录中,运行新建命令。

例如,我需要在D:\00Coding\Python\scrapy目录下存放该项目,打开命令窗口,进入该目录,执行以下命令:

scrapy startproject  tutorial

PS:tutorial可以替换成任何你喜欢的名称,最好是英文

该命令将会创建包含下列内容的 tutorial 目录:

tutorial/
scrapy.cfg
tutorial/
__init__.py
items.py
pipelines.py
settings.py
spiders/
__init__.py
...

这些文件分别是:

scrapy.cfg: 项目的配置文件
tutorial/: 该项目的python模块。之后您将在此加入代码。
tutorial/items.py: 项目中的item文件.
tutorial/pipelines.py: 项目中的pipelines文件.
tutorial/settings.py: 项目的设置文件.
tutorial/spiders/: 放置spider代码的目录.

2、定义Item

Item 是保存爬取到的数据的容器;其使用方法和python字典类似,并且提供了额外保护机制来避免拼写错误导致的未定义字段错误。我们需要从想要爬取的网站(这里爬取新浪新闻)中获取以下属性:

新闻大类url、新闻大类title;

新闻小类url、新闻小类title;

新闻url、新闻title;

新闻标题、新闻内容;

对此,在item中定义相应的字段。编辑tutorial目录中的 items.py 文件:

  1. from scrapy.item import Item, Field
  2. class TutorialItem(Item):
  3. # define the fields for your item here like:
  4. # name = scrapy.Field()
  5. parent_title = Field()
  6. parent_url = Field()
  7. second_title = Field()
  8. second_url = Field()
  9. path = Field()
  10. link_title = Field()
  11. link_url = Field()
  12. head= Field()
  13. content = Field()
  14. pass

3、编写爬虫(Spider)

Spider是用户编写用于从单个网站(或者一些网站)爬取数据的类。

1、sinaSpider.py文件:

包含了一个用于下载的初始URL,如何跟进网页中的链接以及如何分析页面中的内容,提取生成 item 的方法。为了创建一个Spider,您必须继承 scrapy.Spider 类,且定义以下三个属性:

name:用于区别Spider。该名字必须是唯一的,您不可以为不同的Spider设定相同的名字。

start_urls:包含了Spider在启动时进行爬取的url列表。因此,第一个被获取到的页面将是其中之一。后续的URL则从初始的URL获取到的数据中提取。

parse() 是spider的一个方法。被调用时,每个初始URL完成下载后生成的Response 对象将会作为唯一的参数传递给该函数。该方法负责解析返回的数据(response data),提取数据(生成item)以及生成需要进一步处理的URL的Request 对象。

当我们爬取了大类,然后这时候没有保存item,而是传递item到小类,爬取完小类之后,我们需要去新闻详情页爬取新闻的内容和标题:

主要思路是:paser->second_paser->detail_parse

以下是sinaSpider的全部代码:

  1. # -*-coding: utf-8 -*-
  2. __author__= 'George'
  3. import sys, os
  4. reload(sys)
  5. sys.setdefaultencoding("utf-8")
  6. from scrapy.spider import Spider
  7. from scrapy.http import Request
  8. from scrapy.selector import Selector
  9. from tutorial.items import TutorialItem
  10. base ="d:/dataset/" #存放文件分类的目录
  11. class SinaSpider(Spider):
  12. name= "sina"
  13. allowed_domains= ["sina.com.cn"]
  14. start_urls= [
  15. "http://news.sina.com.cn/guide/"
  16. ]#起始urls列表
  17. def parse(self, response):
  18. items= []
  19. sel= Selector(response)
  20. big_urls=sel.xpath('//div[@id=\"tab01\"]/div/h3/a/@href').extract()#大类的url
  21. big_titles=sel.xpath("//div[@id=\"tab01\"]/div/h3/a/text()").extract()
  22. second_urls =sel.xpath('//div[@id=\"tab01\"]/div/ul/li/a/@href').extract()#小类的url
  23. second_titles=sel.xpath('//div[@id=\"tab01\"]/div/ul/li/a/text()').extract()
  24. for i in range(1,len(big_titles)-1):#这里不想要第一大类,big_title减去1是因为最后一个大类,没有跳转按钮,也去除
  25. file_name = base + big_titles[i]
  26. #创建目录
  27. if(not os.path.exists(file_name)):
  28. os.makedirs(file_name)
  29. for j in range(19,len(second_urls)):
  30. item = TutorialItem()
  31. item['parent_title'] =big_titles[i]
  32. item['parent_url'] =big_urls[i]
  33. if_belong =second_urls[j].startswith( item['parent_url'])
  34. if(if_belong):
  35. second_file_name =file_name + '/'+ second_titles[j]
  36. if(not os.path.exists(second_file_name)):
  37. os.makedirs(second_file_name)
  38. item['second_url'] = second_urls[j]
  39. item['second_title'] =second_titles[j]
  40. item['path'] =second_file_name
  41. items.append(item)
  42. for item in items:
  43. yield Request(url=item['second_url'],meta={'item_1': item},callback=self.second_parse)
  44. #对于返回的小类的url,再进行递归请求
  45. def second_parse(self, response):
  46. sel= Selector(response)
  47. item_1= response.meta['item_1']
  48. items= []
  49. bigUrls= sel.xpath('//a/@href').extract()
  50. for i in range(0, len(bigUrls)):
  51. if_belong =bigUrls[i].endswith('.shtml') and bigUrls[i].startswith(item_1['parent_url'])
  52. if(if_belong):
  53. item = TutorialItem()
  54. item['parent_title'] =item_1['parent_title']
  55. item['parent_url'] =item_1['parent_url']
  56. item['second_url'] =item_1['second_url']
  57. item['second_title'] =item_1['second_title']
  58. item['path'] = item_1['path']
  59. item['link_url'] = bigUrls[i]
  60. items.append(item)
  61. for item in items:
  62. yield Request(url=item['link_url'], meta={'item_2':item},callback=self.detail_parse)
  63. def detail_parse(self, response):
  64. sel= Selector(response)
  65. item= response.meta['item_2']
  66. content= ""
  67. head=sel.xpath('//h1[@id=\"artibodyTitle\"]/text()').extract()
  68. content_list=sel.xpath('//div[@id=\"artibody\"]/p/text()').extract()
  69. for content_one in content_list:
  70. content += content_one
  71. item['head']= head
  72. item['content']= content
  73. yield item

2、pipelines.py

     主要是对于抓取数据的保存(txt),这里把文件名命名为链接中'/'替换成'_'

  1. # -*- coding: utf-8 -*-
  2. # Define your item pipelines here
  3. #
  4. # Don't forget to add your pipeline to the ITEM_PIPELINES setting
  5. # See: http://doc.scrapy.org/en/latest/topics/item-pipeline.html
  6. from scrapy import signals
  7. import json
  8. import codecs
  9. import sys
  10. reload(sys)
  11. sys.setdefaultencoding( "utf-8" )
  12. class SinaPipeline(object):
  13. def process_item(self, item, spider):
  14. link_url = item['link_url']
  15. file_name = link_url[7:-6].replace('/','_')
  16. file_name += ".txt"
  17. fp = open(item['path']+'/'+file_name, 'w')
  18. fp.write(item['content'])
  19. fp.close()
  20. return item

3、setting.py

    这是设置文件,这里需要设置同时开启的线程数目、日志打印的级别等

  1. # -*- coding: utf-8 -*-
  2. BOT_NAME = 'tutorial'
  3. SPIDER_MODULES = ['tutorial.spiders']
  4. NEWSPIDER_MODULE = 'tutorial.spiders'
  5. ITEM_PIPELINES = {
  6. 'tutorial.pipelines.SinaPipeline': 300,
  7. }
  8. LOG_LEVEL = 'INFO'
  9. ROBOTSTXT_OBEY = True

爬取结果

这里的文件夹是根据分类,然后创建的;

这是大类的文件夹,现在我们已经将item都爬下来了,就需要存了,这里只想要存内容,所以直接将item里面的content字段的内容写入txt。

这里通过将链接进行处理,转换成文件名,最后保存到所属的那个类里;

Scrapy教程——搭建环境、创建项目、爬取内容、保存文件的更多相关文章

  1. pymysql 使用twisted异步插入数据库:基于crawlspider爬取内容保存到本地mysql数据库

    本文的前提是实现了整站内容的抓取,然后把抓取的内容保存到数据库. 可以参考另一篇已经实现整站抓取的文章:Scrapy 使用CrawlSpider整站抓取文章内容实现 本文也是基于这篇文章代码基础上实现 ...

  2. python爬虫之爬取糗事百科并将爬取内容保存至Excel中

    本篇博文为使用python爬虫爬取糗事百科content并将爬取内容存入excel中保存·. 实验环境:Windows10   代码编辑工具:pycharm 使用selenium(自动化测试工具)+p ...

  3. 从零开始学Xamarin.Forms(二) 环境搭建、创建项目

    原文:从零开始学Xamarin.Forms(二) 环境搭建.创建项目 一.环境搭建 Windows下环境搭建:     1.下载并安装jdk.Android SDK和NDK,当然还需要 VS2013 ...

  4. vue--1.环境搭建及创建项目

    转自https://blog.csdn.net/junshangshui/article/details/80376489 一.环境搭建及创建项目 1.安装node.js,webpack 2.安装vu ...

  5. Python爬虫教程-13-爬虫使用cookie爬取登录后的页面(人人网)(下)

    Python爬虫教程-13-爬虫使用cookie爬取登录后的页面(下) 自动使用cookie的方法,告别手动拷贝cookie http模块包含一些关于cookie的模块,通过他们我们可以自动的使用co ...

  6. python爬虫项目-爬取雪球网金融数据(关注、持续更新)

    (一)python金融数据爬虫项目 爬取目标:雪球网(起始url:https://xueqiu.com/hq#exchange=CN&firstName=1&secondName=1_ ...

  7. 【python爬虫】对喜马拉雅上一个专辑的音频进行爬取并保存到本地

    >>>内容基本框架: 1.爬虫目的 2.爬取过程 3.代码实现 4.爬取结果  >>>实验环境: python3.6版本,pycharm,电脑可上网. [一 爬虫目 ...

  8. 简单的爬虫爬的完整的<img>标签,修改正则即可修改爬取内容

    简单的爬虫爬的完整的<img>标签,生成<img>标签结果文件与爬虫经历的网页. <?php/** 从给定的url获取html内容** */function _getUr ...

  9. python爬虫爬取内容中,-xa0,-u3000的含义

    python爬虫爬取内容中,-xa0,-u3000的含义 - CSDN博客 https://blog.csdn.net/aiwuzhi12/article/details/54866310

随机推荐

  1. 第一章、接口规范之Restful规范

    阅读目录 2.1 数据的安全保障 2.2 接口特征表现 2.3 多数据版本共存 2.4 数据即是资源 2.5 资源操作由请求方式决定 3.1 正常响应 3.2 重定向响应 3.3 客户端异常 3.4 ...

  2. 第一章、接口规范之web-api接口

    1.什么是Web API接口 通过网络,规定了前后台信息交互规则的url链接,也就是前后台信息交互的媒介 Web API接口和一般的url链接还是有区别的,Web API接口简单概括有下面四大特点 u ...

  3. Airflow安装错误:sqlalchemy.exc.OperationalError: (_mysql_exceptions.OperationalError)

    1 完整的异常信息: raise errorclass, errorvalue sqlalchemy.exc.OperationalError: (_mysql_exceptions.Operatio ...

  4. os.path:平台独立的文件名管理

    介绍 利用os.path模块中包含的函数,很容易编写代码来处理多个平台上的文件 解析路径 import os.path ''' os.path中的第一组函数可以用来将表示文件名的字符串解析为文件名的各 ...

  5. Django学习:连接Mysql数据库

    开发环境: Windows 10 Python 3.7.4 Django 2.2.6 Mysql 8.0.17 承接上一节:https://www.cnblogs.com/daydayupup/p/1 ...

  6. Linux基础篇之FTP服务器搭建(一)

    一.配置网络可以访问互联网(没有条件的可以提前下载相关版本的依赖包(也叫安装包,以下统称依赖包)上传到系统中也可以). 二.检查系统中是否存在相关的依赖包. 没有返回信息,说明系统中不存在相关的依赖包 ...

  7. 11_Redis_事务

    一:Redis 事务:目的为了进行Redis语句的批量化操作,不保证数据安全 Redis作为NoSQL数据库也同样提供了事务机制:在Redis中,MULTI/EXEC/DISCARD/这三个命令是我们 ...

  8. rdb和aof二种持久化方式对比(Redis)

    我们已经知道对于一个企业级的redis架构来说,持久化是不可减少的 企业级redis集群架构:海量数据.高并发.高可用 持久化主要是做灾难恢复,数据恢复,也可以归类到高可用的一个环节里面去 比如你re ...

  9. tensorflow模型的保存与恢复,以及ckpt到pb的转化

    转自 https://www.cnblogs.com/zerotoinfinity/p/10242849.html 一.模型的保存 使用tensorflow训练模型的过程中,需要适时对模型进行保存,以 ...

  10. iview 如何在表格中给操作图标添加Tooltip文字提示?

    项目需要用到的iview 表格中操作项目有各种各样的图标,而各种各样的图标代表不同的操作,面对新用户可能很懵,那如何给这些图标添加Tooltip文字提示? 废话不多讲,直接看代码: <templ ...