Python Scrapy爬虫框架如何使用

技术Python Scrapy爬虫框架如何使用本篇内容介绍了“Python Scrapy爬虫框架如何使用”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希

本文介绍了关于“如何使用Python爬虫框架”的知识。很多人在实际办案过程中都会遇到这样的困难。接下来,让边肖带领大家学习如何应对这些情况!希望大家认真阅读,学点东西!

1、项目创建

创建一个剪贴簿项目非常简单。一般来说,为了快速创建,可以通过终端直接输入以下代码:

scrapystartprojectzhuanti_new

如果你想在不同的文件中创建这个项目,你需要先找到相应的文件路径。当然也可以通过pycharm点击对应文件左下角的终端直接创建,项目会在对应的项目文件中直接创建一个Scrapy项目。

Python  Scrapy爬虫框架如何使用

2、Scrapy项目文件介绍

下面的截图展示了一个Scrapy项目有哪些文件,需要同时创建和生成哪些文件,后面会一一介绍。

Python  Scrapy爬虫框架如何使用

(1)顶层zhuanti_new文件夹是Scrapy的项目名称。

(2)第二层有4个文件:

第一个:和项目同名的文件就是我们通常所说的爬虫包,所有的爬虫代码都在这个包里。

第二个:main文件,是用来运行这个项目的主要功能代码文件。代码编写完成后,它将作为一个整体在这个文件中运行。

3号:配置文件,说明默认设置文件的位置是Juanti _ new模块下的设置文件,将项目名称定义为Juanti _ new。

第4:用于存储搜索结果的txt文件

对于第一个文件中的关键代码文件,请逐一介绍:

(1)items.py文件:定义爬虫捕获的字段信息。

Python  Scrapy爬虫框架如何使用

(2)pipelines.py文件:主要用于数据处理、清洗和存储。

Python  Scrapy爬虫框架如何使用

(3)settings.py:主要用于设置请求头、告警处理等相关问题。

Python  Scrapy爬虫框架如何使用

(4) Zhuantspider.py文件:专注于数据抓取过程的代码文件,也是新建立的文件。

代码如下:

从zhuanti_new.items导入zhuantiewiteimport scrapy from scrapy . selector class导入jianuspiderspider(scrapy。spider): name=' zhantispider ' allowed _ domain=[' jianshu.com ']start _ URL=[' https://www . jianshu.com/records?page=1 order _ by=hot ']# print(start _ URL)def parse(self,response) : ' '解析外部页面'''选择器=selector (response) nbsp

; partical_urls = selector.re('<div class="count"><a target="_blank" href="(.*?)">', selector)       for url in partical_urls:           print(url)           right_url = response.urljoin(url)           #print(right_url)           parts = ['?order_by=added_at&page={0}'.format(k) for k in range(1, 11)]           for part in parts:               # 要爬取每个专题的前10个文章的信息               real_url = right_url + part               #print(real_url)               yield scrapy.Request(real_url, callback=self.parse_detail)
      links = ['https://www.jianshu.com/recommendations/collections?page={}&order_by=hot'.format(i) for i in                range(2, 3)]       for link in links:           print(link)           request = scrapy.Request(link, callback=self.parse)           yield request
  def parse_detail(self, response):       selector = Selector(response)       content = selector.xpath('//div[@class="content"]')       for detail in content:           try:               title = detail.xpath('a[1]/text()').extract_first()               summary = detail.xpath('p/text()').extract_first().strip()               author = detail.xpath('div/a[1]/text()').extract_first()               # comments = detail.xpath('div/a[2]/text()').extract_first()这样是不行的               comments = detail.xpath('div/a[2]/text()').extract()[1].strip()               likes = detail.xpath('div/span[1]/text()').extract_first().strip()               money = detail.xpath('div/span[2]/text()').extract_first()
              item = ZhuantiNewItem()               if money is not None:                   item['title'] = title                   item['summary'] = summary                   item['author'] = author                   item['comments'] = comments                   item['likes'] = likes                   item['money'] = money.strip()               else:                   item['title'] = title                   item['summary'] = summary                   item['author'] = author                   item['comments'] = comments                   item['likes'] = likes               print(item)               yield item           except:               pass

以上就是最主要的几个文件,对于初学者只要按照对应要求完成这几个文件的代码填写就可以爬取到数据。

3、案例运行及结果

现在开始运行整体代码,就需要创建上述的main文件了,具体main文件代码如下:

Python Scrapy爬虫框架如何使用

运行的爬虫文件为:zhuantispider,务必不要写成Scrapy项目名称

爬取运行结果如下:

Python Scrapy爬虫框架如何使用

“Python Scrapy爬虫框架如何使用”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注网站,小编将为大家输出更多高质量的实用文章!

内容来源网络,如有侵权,联系删除,本文地址:https://www.230890.com/zhan/113490.html

(0)

相关推荐

  • 喜怎么读,喜字下面加个心字念什么

    技术喜怎么读,喜字下面加个心字念什么憙 拼音:xǐ 部首:心,部外笔画:12,总笔画:16五笔86&98:FKUN 仓颉:GRP 笔顺编号:1212514312514544 四角号码:40336 UniCode:

    生活 2021年10月27日
  • 抖音刷评价平台,抖音免费刷点赞神器

    技术抖音刷评价平台,抖音免费刷点赞神器抖音刷评价平台,抖音免费刷点赞神器
    抖音免费刷赞手机版
    第四个就是播放完整度。播放完整度说白了就是人们打开你这个视频之后,能否看得完,是打开看了两三秒就换下一个,还是耐着性子从头看

    测评 2021年11月13日
  • 鲁拼音和组词,“兼”的读音和组词分别是什么

    技术鲁拼音和组词,“兼”的读音和组词分别是什么【拼音】鲁拼音和组词:jiān【解释】:
    1、同时涉及、处理或具有几方面的情况:兼职、兼顾、软硬兼施、德才兼备。
    2、加倍,合并:兼并、兼程。
    3、兼有主次之分,如董事长兼经

    生活 2021年10月27日
  • 怎么从Spring的几个阶段理解其工作过程

    技术怎么从Spring的几个阶段理解其工作过程这篇文章给大家介绍怎么从Spring的几个阶段理解其工作过程,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。Spring框架非常强大,想要彻底弄懂Spri

    攻略 2021年12月2日
  • oracle中keep分析函数(oracle表空间巡视)

    技术Oracle调优中常用表KEEP到内存中的示例分析本篇文章为大家展示了Oracle调优中常用表KEEP到内存中的示例分析,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。数据迁移

    攻略 2021年12月24日
  • 如何进行CVE-2017-16943-进出口-UAF脆弱性分析

    技术怎么进行CVE-2017-16943-Exim-UAF漏洞分析本篇文章为大家展示了怎么进行CVE-2017-16943-Exim-UAF漏洞分析,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希

    2021年12月20日