# -*- coding: utf-8 -*-
"""
语言版本:
python:3.6.1
scrapy:1.3.3
功能:本蜘蛛主要演示如何爬取多个页面
作者:cuanboy
出处:http://www.scrapyd.cn (scrapy中文网)
时间:2017年12月16日15:55:00
运行:CMD模式进入该项目目录,输入命令:scrapy crawl nextSpider
"""
import scrapy
class NextSpiderSpider(scrapy.Spider):
name = "nextSpider"
allowed_domains = ["lab.scrapyd.cn"]
start_urls = ['http://lab.scrapyd.cn/']
def parse(self, response):
mingyan = response.css('div.quote') # 提取首页所有名言,保存至变量mingyan
for v in mingyan: # 循环获取每一条名言里面的:名言内容、作者、标签
text = v.css('.text::text').extract_first() # 提取名言
autor = v.css('.author::text').extract_first() # 提取作者
tags = v.css('.tags .tag::text').extract() # 提取标签
tags = ','.join(tags) # 数组转换为字符串
"""
接下来进行写文件操作,每个名人的名言储存在一个txt文档里面
"""
fileName = '%s-语录.txt' % autor # 定义文件名,如:木心-语录.txt
with open(fileName, "a+") as f: # 不同人的名言保存在不同的txt文档,“a+”以追加的形式
f.write(text)
f.write('\n') # ‘\n’ 表示换行
f.write('标签:' + tags)
f.write('\n-------\n')
f.close()
# 以上都内容是上几节课的内容
# 接下来我们需要判断下一页是否存在,如果存在
# 我们需要继续提交给parse执行关键看 scrapy 如何实现链接提交
next_page = response.css('li.next a::attr(href)').extract_first() # css选择器提取下一页链接
if next_page is not None: # 判断是否存在下一页
"""
如果是相对路径,如:/page/1
urljoin能替我们转换为绝对路径,也就是加上我们的域名
最终next_page为:http://lab.scrapyd.cn/page/2/
"""
next_page = response.urljoin(next_page)
"""
接下来就是爬取下一页或是内容页的秘诀所在:
scrapy给我们提供了这么一个方法:scrapy.Request()
这个方法还有许多参数,后面我们慢慢说,这里我们只使用了两个参数
一个是:我们继续爬取的链接(next_page),这里是下一页链接,当然也可以是内容页
另一个是:我们要把链接提交给哪一个函数(callback=self.parse)爬取,这里是parse函数,也就是本函数
当然,我们也可以在下面另写一个函数,比如:内容页,专门处理内容页的数据
经过这么一个函数,下一页链接又提交给了parse,那就可以不断的爬取了,直到不存在下一页
"""
yield scrapy.Request(next_page, callback=self.parse)