html豆瓣看过的电影源码,5.28-豆瓣电影信息爬取

该程序使用Python实现,通过分析豆瓣电影网页源码,动态获取不同类型的电影(热门、最新、经典、华语)Top 100的电影信息,包括电影名、评分和封面。通过输入电影类型,程序会自动爬取并展示相应电影数据。程序利用requests库发送HTTP请求,使用json解析数据,同时运用lxml库处理HTML。

程序实现目标

用户输入电影类型,如【热门 最新 经典 华语】 可获得此分类排名 Top 100 电影信息(电影名 评分 封面链接)

程序实现工具

星愿浏览器 以chromium为内核,操作方法与 chorme类似

Microsoft Visual Studio

程序设计分析

以 华语电影 为例,抓取此类型的数据,其他电影类型以此类推

0c45f9bd3d67

华语电影

1. 分析数据来源

通过观察源码中是否有数据,判断是否是动态加载

0c45f9bd3d67

判断是否是动态加载

进入源代码界面,ctrl + f 搜索一个前端页面中展示出的电影名

例:此处搜索《流浪地球》得到结果为0

0c45f9bd3d67

数据动态加载

2.查找电影信息位置

网页端按下 F12 调出浏览器的控制台;选择 network,按 F5 刷新

0c45f9bd3d67

刷新后页面

依次选择 XHR 加载 json 链接 - response

0c45f9bd3d67

此处可以清楚地看到我们所需的信息

点击 headers,查看其发送的链接地址和方法

0c45f9bd3d67

关注 Request URL 和 Request Method

将 链接地址 复制到浏览器中加载,可以得到如下内容

0c45f9bd3d67

华语电影信息

3. 获取更多电影信息

返回 选电影 界面,点击 加载更多 ,观察 链接 的变化

0c45f9bd3d67

加载前 page_start=0

0c45f9bd3d67

加载更多

0c45f9bd3d67

加载后 page_start=20

得到结论:若要 加载更多,只需改变 page_start

程序设计过程

1. 引入所需的包

#coding=ut f-8

import requests

import time

import json

from lxml import etree

2. 创建一个类,并定义 init

(包含 url列表和请求头)

class DoubanMovieSpider:

def __init__(self):

# 定义一个url列表,可以存放各种类别的url链接,这里只存放了华语电影的链接

self.url_list_temp = [

{

"url_temp": "https://movie.douban.com/j/search_subjects?type=movie&tag=%E5%8D%8E%E8%AF%AD&sort=recommend&page_limit=20&page_start={}",

"country": "CN"

}

]

# 定义请求头headers

self.headers = {

"Accept" : "*/*",

"Accept-Encoding" : "gzip, deflate, br",

"Accept-Language" : "zh,zh-TW;q=0.9,en-US;q=0.8,en;q=0.7,zh-CN;q=0.6",

"Connection" : "keep-aliv

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符  | 博主筛选后可见
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值