首先要做的就是去豆瓣网找对应的接口,这里就不赘述了,谷歌浏览器抓包即可,然后要做的就是分析返回的json数据的结构:

https://movie.douban.com/j/search_subjects?type=tv&tag=%E5%9B%BD%E4%BA%A7%E5%89%A7&sort=recommend&page_limit=20&page_start=0

这是接口地址,可以大概的分析一下各个参数的规则:

type=tv,表示的是电视剧的分类

tag=国产剧,表示是国产剧的分类

sort参数,这里猜测是一个排序方式

page_limit=20,这个一定就是每页所存取的数据数量了

page_start=0,表示的是这页从哪条数据开始,比如第二页就为page_start=20,第三页为page_start=40,以此类推

最终我们要用到的主要是page_start和page_limit两个参数

下面这里是返回的json数据格式,可以看出我们要的是json中subjects列表中的每条数据,在之后的程序中会把每一个电视剧的信息保存到文件里的一行

有了这些,就直接上程序了,因为感觉程序还是比较好懂,主要还是遵从面向对象的程序设计:

import json

import requests

class DoubanSpider(object):

"""爬取豆瓣热门国产电视剧的数据并保存到本地"""

def __init__(self):

# url_temp中的start的值是动态的,所以这里用{}替换,方便后面使用format方法

self.url_temp = 'https://movie.douban.com/j/search_subjects?type=tv&tag=%E5%9B%BD%E4%BA%A7%E5%89%A7&sort=recommend&page_limit=20&page_start={}'

self.headers = {

'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/75.0.3770.100 Safari/537.36',

}

def pass_url(self, url): # 发送请求,获取响应

print(url)

response = requests.get(url, headers=self.headers)

return response.content.decode()

def get_content_list(self, json_str): # 提取数据

dict_ret = json.loads(json_str)

content_list = dict_ret['subjects']

return content_list

def save_content_list(self, content_list): # 保存

with open('douban.txt', 'a', encoding='utf-8') as f:

for content in content_list:

f.write(json.dumps(content, ensure_ascii=False)) # 一部电视剧的信息一行

f.write('\n') # 写入换行符进行换行

print('保存成功!')

def run(self): # 实现主要逻辑

num = 0

while True:

# 1. start_url

url = self.url_temp.format(num)

# 2. 发送请求,获取响应

json_str = self.pass_url(url)

# 3. 提取数据

content_list = self.get_content_list(json_str)

# 4. 保存

self.save_content_list(content_list)

if len(content_list) < 20:

break

# 5. 构造下一页url地址,进入循环

num += 20 # 每一页有二十条数据

if __name__ == '__main__':

douban_spider = DoubanSpider()

douban_spider.run()

上面是利用循环遍历每一页,后来我又想到用递归也可以,虽然递归效率可能不高,这里还是展示一下,只需要改几个地方而已:

import json

import requests

class DoubanSpider(object):

"""爬取豆瓣热门国产电视剧的数据并保存到本地"""

def __init__(self):

# url_temp中的start的值是动态的,所以这里用{}替换,方便后面使用format方法

self.url_temp = 'https://movie.douban.com/j/search_subjects?type=tv&tag=%E5%9B%BD%E4%BA%A7%E5%89%A7&sort=recommend&page_limit=20&page_start={}'

self.headers = {

'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/75.0.3770.100 Safari/537.36',

}

self.num = 0

def pass_url(self, url): # 发送请求,获取响应

print(url)

response = requests.get(url, headers=self.headers)

return response.content.decode()

def get_content_list(self, json_str): # 提取数据

dict_ret = json.loads(json_str)

content_list = dict_ret['subjects']

return content_list

def save_content_list(self, content_list): # 保存

with open('douban2.txt', 'a', encoding='utf-8') as f:

for content in content_list:

f.write(json.dumps(content, ensure_ascii=False)) # 一部电视剧的信息一行

f.write('\n') # 写入换行符进行换行

print('保存成功!')

def run(self): # 实现主要逻辑

# 1. start_url

url = self.url_temp.format(self.num)

# 2. 发送请求,获取响应

json_str = self.pass_url(url)

# 3. 提取数据

content_list = self.get_content_list(json_str)

# 4. 保存

self.save_content_list(content_list)

# 5. 构造下一页url地址,进入循环

if len(content_list) == 20:

self.num += 20 # 每一页有二十条数据

self.run()

if __name__ == '__main__':

douban_spider = DoubanSpider()

douban_spider.run()

最终文件得到的结果:

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

本文标题: python requests库爬取豆瓣电视剧数据并保存到本地详解

本文地址: http://www.cppcns.com/jiaoben/python/268014.html

python爬豆瓣电视剧_python requests库爬取豆瓣电视剧数据并保存到本地详解相关推荐

  1. python画罗小黑_Python3+requests库爬取豆瓣《罗小黑战记》评论

    贴一下抓到的评论,最后几条的 本渣是在校学生(非计算机相关),今年上半年接触Python,然后暑假开始学着写爬虫. 新手,本文如有错误,谢谢指正. 这个爬虫开始思路有点乱,现在比较清晰了 思路:req ...

  2. python播放视频代码_Python中操作各种多媒体,视频、音频到图片的代码详解

    我们经常会遇到一些对于多媒体文件修改的操作,像是对视频文件的操作:视频剪辑.字幕编辑.分离音频.视频音频混流等.又比如对音频文件的操作:音频剪辑,音频格式转换.再比如我们最常用的图片文件,格式转换.各 ...

  3. python内置函数调用_Python中函数的基本定义与调用及内置函数详解

    前言 函数function是python编程核心内容之一,也是比较重要的一块.首先我们要了解Python函数的基本定义: 函数是什么? 函数是可以实现一些特定功能的小方法或是小程序.在Python中有 ...

  4. python获取网页json返回空_Python用requests库爬取返回为空的解决办法

    首先介紹一下我們用360搜索派取城市排名前20. 我们爬取的网址:https://baike.so.com/doc/24368318-25185095.html 我们要爬取的内容: html字段: r ...

  5. python爬虫电影信息_Python爬虫入门 | 爬取豆瓣电影信息

    这是一个适用于小白的Python爬虫免费教学课程,只有7节,让零基础的你初步了解爬虫,跟着课程内容能自己爬取资源.看着文章,打开电脑动手实践,平均45分钟就能学完一节,如果你愿意,今天内你就可以迈入爬 ...

  6. python使用requests库爬取淘宝指定商品信息

    python使用requests库爬取淘宝指定商品信息 在搜索栏中输入商品 通过F12开发者工具抓包我们知道了商品信息的API,同时发现了商品数据都以json字符串的形式存储在返回的html内 解析u ...

  7. 用python爬取qq空间内容_利用Fiddler抓包和py的requests库爬取QQ空间说说内容并写入文件...

    [Python] 纯文本查看 复制代码#!C:\Program Files\Python36 python # -*- coding: UTF-8 -*- """ @au ...

  8. python的requests库发送携带上传文件的接口_python requests 库请求带有文件参数的接口实例...

    python requests 库请求带有文件参数的接口实例 有些接口参数是一个文件格式,比如fiddler 抓包参数如下显示 这个接口的 form-data fiddler 显示的和不带文件参数的接 ...

  9. 用Requests库爬取微博照片

    用Requests库爬取微博照片 代码如下: #微博图片爬取 import requests import os #文件目录方法模块 url="https://wx3.sinaimg.cn/ ...

最新文章

  1. DDR: efficient computational method to predict drug–target interactions using graph mining and machi
  2. Ruby种的特殊变量
  3. CBU计算机硕士申请难度,电脑开机后CBU百分只百是什么问题
  4. 低代码音视频开发训练营
  5. 生命的力量:萝卜开花
  6. MATLAB求音频信号特征的自定义函数.md
  7. 一步步编写操作系统3 部署工作环境 3
  8. Linux进程全解6——进程的诞生和消亡
  9. 阿里1682亿背后的协同研发云——云效公共云正式商业化 1
  10. dell m610刀片查看日志及更换内存
  11. qq群t人php,QQ群机器人,自动加人、T人、与人聊天,你不在,有机器人呢
  12. web逻辑思维题目_逻辑思维训练500题以及答案
  13. Linux自学day2
  14. mysql中YEARWEEK跨年引发的线上问题
  15. 卡耐基梅隆大学计算机熬夜,卡耐基梅隆大学:作为一所CS牛校,我也很无奈啊...
  16. 按照分类方法判断图片里是否有鹅蛋
  17. MySQL枚举类型的“八宗罪”
  18. 多元回归——matlab,R与spss
  19. 【Qt】实现一个计算器
  20. 维吉尼亚密码加解密与破解

热门文章

  1. LayUI: 工具条toolbar 绑定事件lay-event
  2. 利用爬虫将PDF的参考文献放在word中
  3. java8用chars_为什么String.chars()是Java 8中的int数据流?
  4. kafka基础架构(概念篇)
  5. 拉斯维加斯算法与N皇后问题
  6. n皇后的拉斯维加斯回溯算法
  7. 58.订单明细实时表和商品、品牌、spu 等维表关联
  8. 基于JAVA车牌信息管理系统计算机毕业设计源码+系统+lw文档+部署
  9. Mac5款高效实用软件,值得推荐
  10. JAVA File.renameTo()方法使用