Python scrapy爬取起点中文网小说榜单
一、项目需求
爬取排行榜小说的作者,书名,分类以及完结或连载
二、项目分析
目标url:“https://www.qidian.com/rank/hotsales?style=1&page=1”
通过控制台搜索发现相应信息均存在于html静态网页中,所以此次爬虫难度较低。
通过控制台观察发现,需要的内容都在一个个li列表中,每一个列表代表一本书的内容。
在li中找到所需的内容
找到第两页的url
“https://www.qidian.com/rank/hotsales?style=1&page=1”
“https://www.qidian.com/rank/hotsales?style=1&page=2”
对比找到页数变化
开始编写scrapy程序。
三、程序编写
创建项目太简单,不说了
1.编写item(数据存储)
import scrapy class QidianHotItem(scrapy.Item): name = scrapy.Field() #名称 author = scrapy.Field() #作者 type = scrapy.Field() #类型 form= scrapy.Field() #是否完载
2.编写spider(数据抓取(核心代码))
#coding:utf-8 from scrapy import Request from scrapy.spiders import Spider from ..items import QidianHotItem #导入下需要的库 class HotSalesSpider(Spider):#设置spider的类 name = "hot" #爬虫的名称 qidian_header={"user-agent":"Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/90.0.4430.93 Safari/537.36"} #设置header current_page = 1 #爬虫起始页 def start_requests(self): #重写第一次请求 url="https://www.qidian.com/rank/hotsales?style=1&page=1" yield Request(url,headers=self.qidian_header,callback=self.hot_parse) #Request发起链接请求 #url:目标url #header:设置头部(模拟浏览器) #callback:设置页面抓起方式(空默认为parse) def hot_parse(self, response):#数据解析 #xpath定位 list_selector=response.xpath("//div[@class='book-mid-info']") #获取所有小说 for one_selector in list_selector: #获取小说信息 name=one_selector.xpath("h4/a/text()").extract()[0] #获取作者 author=one_selector.xpath("p[1]/a[1]/text()").extract()[0] #获取类型 type=one_selector.xpath("p[1]/a[2]/text()").extract()[0] # 获取形式 form=one_selector.xpath("p[1]/span/text()").extract()[0] item = QidianHotItem() #生产存储器,进行信息存储 item['name'] = name item['author'] = author item['type'] = type item['form'] = form yield item #送出信息 # 获取下一页URL,并生成一个request请求 self.current_page += 1 if self.current_page <= 10:#爬取前10页 next_url = "https://www.qidian.com/rank/hotsales?style=1&page="+str(self.current_page) yield Request(url=next_url,headers=self.qidian_header,callback=self.hot_parse) def css_parse(self,response): #css定位 list_selector = response.css("[class='book-mid-info']") for one_selector in list_selector: # 获取小说信息 name = one_selector.css("h4>a::text").extract()[0] # 获取作者 author = one_selector.css(".author a::text").extract()[0] # 获取类型 type = one_selector.css(".author a::text").extract()[1] # 获取形式 form = one_selector.css(".author span::text").extract()[0] # 定义字典 item=QidianHotItem() item['name']=name item['author'] = author item['type'] = type item['form'] = form yield item
3.start.py(代替命令行)
在爬虫项目文件夹下创建start.py。
from scrapy import cmdline #导入cmd命令窗口 cmdline.execute("scrapy crawl hot -o hot.csv" .split()) #运行爬虫并生产csv文件
出现类似的过程代表爬取成功。
hot.csv
总结
本次爬虫内容还是十分简单的因为只用了spider和item,这几乎是所有scrapy都必须调用的文件,后期还会有middlewarse.py,pipelines.py,setting.py需要编写和配置,以及从javascript和json中提取数据,难度较大。
到此这篇关于Python scrapy爬取起点中文网小说榜单的文章就介绍到这了,更多相关Python爬取起点中文网内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
python3+selenium获取页面加载的所有静态资源文件链接操作
这篇文章主要介绍了python3+selenium获取页面加载的所有静态资源文件链接操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧2020-05-05Django错误:TypeError at / ''bool'' object is not callable解决
这篇文章主要介绍了Django 错误:TypeError at / 'bool' object is not callable解决,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下2019-08-08Python + selenium + crontab实现每日定时自动打卡功能
这篇文章主要介绍了Python + selenium + crontab实现每日定时自动打卡功能,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下2020-03-03python用selenium打开chrome浏览器保持登录方式
大家好,本篇文章主要讲的是python用selenium打开chrome浏览器保持登录方式,感兴趣的同学赶快来看一看吧,对你有帮助的话记得收藏一下2022-02-02基于python使用Pillow做动态图在图中生成二维码以及图像处理
这篇文章主要介绍了基于python使用Pillow做动态图在图中生成二维码以及图像处理,分享pillow的一些简单使用,喜欢的话大家可以参考文章内容下去试试奥2022-02-02
最新评论