猫眼电影Top100爬取

猫眼电影的TOP100榜爬取步骤:

  • 第一步:打开网页猫眼电影榜单网页(https://maoyan.com/board/4)
  • 第二步:打开开发者模式,分析网页源代码,找到需爬取的信息
  • 第三步:编写代码,将整个html请求下来,然后解析网页,获取我们需要的信息并将之存为excel表格

网页分析

在图片描述依次点击图中箭头所指的位置,可以观察到我们所需的信息
在这里插入图片描述
通过上述操作可以发现,我们所需的每部电影的信息都包含在一个<dd>标签中

翻页


通过分析我们可以发现,猫眼榜单中的每页的url带有一个offset,通过修改offset的值,就可以获得其它页面的url。

完整代码如下

import json
import requests
import re
from requests.exceptions import  RequestException
import xlwt

def get_one_page(url):
    try:
        headers={
            'User-Agent':'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/80.0.3987.106 Safari/537.36'
        }
        response = requests.get(url,headers=headers)
        response.encoding = response.apparent_encoding
        if response.status_code == 200:
            return response.text
        return  None
    except RequestException:
        return None

def parse_one_page(html):
    print("开始获取数据")
    pattern = re.compile('<dd>.*?board-index.*?>(\d+)</i>.*?data-src="(.*?)".*?name"><a.*?>(.*?)</a>.*?star">(.*?)</p>.*?releasetime">(.*?)</p>.*?integer">(.*?)</i>.*?fraction">(.*?)</i>',re.S)
    items = re.findall(pattern,html)
    for item in items:
        yield {
            'index':item[0],
            'image':item[1],
            'title':item[2],
            'actor':item[3].strip(),
            'time':item[4].strip()[5:],
            'score':item[5]+item[6]
        }

def write_to_file(content):
    with open('result.txt','a',encoding='utf-8') as f:
        f.write(json.dumps(content,ensure_ascii=False)+'\n')

def write_to_excel(html,worksheet):
    for item in parse_one_page(html):
        print(item)
        global count
        worksheet.write(count,0,item.get('index'))
        worksheet.write(count,1,item.get('score'))
        worksheet.write(count,2,item.get('title'))
        worksheet.write(count,3,item.get('actor'))
        worksheet.write(count,4,item.get('time'))
        worksheet.write(count,5,item.get('image'))
        count=count+1

def main(offset,worksheet):
    url = 'https://maoyan.com/board/4?offset='+str(offset)
    html = get_one_page(url)
    write_to_excel(html,worksheet)
    
if __name__ == '__main__':
    workbook = xlwt.Workbook(encoding='utf-8')
    worksheet = workbook.add_sheet('猫眼电影Top100')
    count = 1
    # 设置单元格的宽度
    worksheet.col(2).width = 256 * 20
    worksheet.col(3).width = 550 * 20
    worksheet.col(4).width = 350 * 20

    worksheet.write(0, 0, '排名')
    worksheet.write(0, 1, '评分')
    worksheet.write(0, 2, '电影名称')
    worksheet.write(0, 3, '主演')
    worksheet.write(0, 4, '上映时间')
    worksheet.write(0, 5, '封面图片')
    for i in range(10):
        main(i*10,worksheet)
    workbook.save('猫眼电影Top100.xls')


评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值