scrapy爬取豆瓣电影top250

# -*- coding: utf-8 -*-
# scrapy爬取豆瓣电影top250

import scrapy
from douban.items import DoubanItem


class DoubanspiderSpider(scrapy.Spider):
    name = "doubanspider"
    # allowed_domains = ["movie.douban.com/top250"]注意这里的主页限制,一旦翻页可能超出范围
    start_urls = ['http://movie.douban.com/top250']

    def parse(self, response):
        item = DoubanItem()
        for each in response.css('.article .grid_view li'):
            # 电影名称
            title = each.css('.item .hd .title:nth-child(1)::text').extract_first()
            # 导演
            dire_actor = each.css('.item .bd p::text').extract()[0].strip()
            director = dire_actor.split('\xa0\xa0\xa0')[0].strip()
            # 演员
            actor = dire_actor.split('\xa0\xa0\xa0')[1].strip()
            # 年代
            info = each.css('.item .bd p::text').extract()[1].strip()
            year = info.split('/')[0].strip()
            # 国家
            country = info.split('/')[1].strip()
            # 类型
            type = info.split('/')[2].strip()
            # 评分
            rating_num = each.css('.item .bd .star .rating_num::text').extract_first()
            # 经典台词
            quote = each.css('.item .bd .quote span::text').extract_first()
            # 海报
            image = each.css('.item .pic a img::attr(src)').extract_first()

            item['title'] = title
            item['director'] = director
            item['actor'] = actor
            item['year'] = year
            item['country'] = country
            item['type'] = type
            item['rating_num'] = rating_num
            item['quote'] = quote
            item['image'] = image

            yield item

        # 构造下一页的请求
        next = response.css('.paginator .next a::attr(href)').extract_first()
        if next:
            url = 'http://movie.douban.com/top250' + next
            print(url)
            yield scrapy.Request(url=url, callback=self.parse)

 

转载于:https://www.cnblogs.com/themost/p/7090247.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值