Scrapy抓取豆瓣电影TOP250所有电影封面

爬虫框架:Scrapy 1.5
目标站点:https://movie.douban.com/top250

豆瓣电影TOP250

目的抓取页面电影封面,并下载到指定目录中。

爬虫项目目录:


爬虫项目目录

爬虫:movie_spider.py

import scrapy
from douban.items import DoubanItem

class MovieSpider(scrapy.Spider):
    name = 'movie'
    start_urls = ['https://movie.douban.com/top250']
    allowed_domains = ['douban.com']

    def parse(self, response):
        movies = response.xpath("//ol[@class='grid_view']//li/div[@class='item']")
        item = DoubanItem() 
        for movie in movies:
            item['title'] = movie.xpath("./div/div/a/span[@class='title'][1]/text()").extract_first()
            item['num'] = movie.xpath(".//div[@class='pic']/em/text()").extract_first()
            item['stars'] = movie.xpath(".//span[@class='rating_num']/text()").extract_first()
            item['src'] = movie.xpath("./div/a/img/@src").extract_first()
            yield item

        next_page = response.xpath("//div[@class='paginator']/span[@class='next']/a/@href").extract_first()
        if next_page is not None:
            next_url = "https://movie.douban.com/top250" + next_page
            yield scrapy.Request(next_url)

管道代码:pipelines.py

import urllib
import os
from scrapy.exceptions import DropItem

class DoubanPipeline(object):
    def __init__(self):
        self.file = open('movies.json','w',encoding='utf-8')
    def process_item(self, item, spider):
        if item['src'] is not None:
            conn = urllib.request.urlopen(item['src'])
            with open("download/"+item['num']+item['title']+".jpg",'wb') as file:
                file.write(conn.read())
                file.close()

配置文件:settings.py
设置访问头和启动管道文件

USER_AGENT = 'Mozilla/5.0 (Macintosh; Intel Mac OS X 10_13_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/70.0.3538.77 Safari/537.36'

ITEM_PIPELINES = {
   'douban.pipelines.DoubanPipeline': 300,
}

执行结果:


电影封面截图
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

友情链接更多精彩内容