仁魔 发表于 2023-4-4 16:48:37

Python:喜欢小姐姐?这不得来一波大采集?

俗话说的好:技能学了~就要用在自己喜欢得东西上!!
这我不得听个话~我喜欢小姐姐,跳舞的小姐姐
这不得用python把小姐姐爬下来~嘿嘿嘿
https://img-blog.csdnimg.cn/36597f2180d34786a5aca0e6938cdadf.png
采集网站

本期目标来自虎牙舞蹈区
https://img-blog.csdnimg.cn/e66ad6a5fb074587b5adcee6c3a513e2.png
开发环境


[*]Python 3.8
[*]Pycharm
模块

requests

re 
基本流程

数据来源分析

确定采集内容是什么? (目标网址, 网址里面数据)
通过开发者工具进行抓包分析, 分析我们想要数据 通过请求那个url地址可以获得
I. 通过分析可以知道 播放url地址是什么?
II. 通过播放地址, 去分析找寻, 数据包是在哪?
III. 通过两个数据包 请求参数对比, 可以知道 只要获取所有ID 就可以获取内容
(图片id MP4ID 音乐ID 还是什么ID 都可以去列表页面获取)
IV. 去分析 mp4ID可以从哪里获取 (一般情况都可以在列表页面获取)
我想要获取播放地址 >>> 要得到数据包 >>> 获取ID
代码实现步骤


[*]发送请求, 对于舞蹈列表页面发送请求
[*]获取数据, 服务器返回数据内容
[*]解析数据, 提取我们想要数据内容 ID
[*]发送请求, 把ID传入到 数据包里面 发送请求
[*]获取数据, 服务器返回数据内容
[*]解析数据, 提取我们想要数据内容 标题 以及播放地址
[*]保存数据, 把内容保存本地
[*]多页数据采集
代码展示

模块
# 导入数据请求模块
import requests   # 第三方模块 pip install requests 需要自行安装
# 导入re正则表达式
import re   # 内置模块 不需要安装
# 导入格式化输出模块
import pprint   # 内置模块 不需要安装 

[*]发送请求, 对于舞蹈视频列表页面发送请求
for page in range(1, 11):
    print(f'正在爬取第{page}页的数据内容')
    url = f'https:// **** .com/g/all?set_id=51&order=hot&page={page}'
    # 爬虫是模拟浏览器对于服务器发送请求, 然后获取服务器返回数据内容
    # Python学习交流裙 708525271
    # user-agent: 用户代理 表示浏览器基本身份信息(一种简单反反爬手段)
    headers = {
      'user-agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/99.0.4844.51 Safari/537.36'
    }
    # 通过requests模块里面get请求方式对于url地址发送请求, 并且携带上headers请求进行伪装, 最后用自定义变量response接收返回数据
    response = requests.get(url=url, headers=headers)
    # <Response > 表示请求成功, 请求网址成功了*** 200状态码表示请求成功, 但是不一定能够得到数据 

[*]获取数据, 服务器返回数据内容 response.text 获取响应文本数据
print(response.text) 

[*]解析数据, 提取我们想要数据内容 视频ID
# 解析方式: css re xpath
# <li data-vid="676382675">想要数据 可以(.*?) 从response.text 里面去找寻这样数据内容
# .*?是可以匹配任意字符(除了\n换行符以外)如果你只是单纯提取数字 最好用 \d+ 匹配一个或者多个数字
video_ids = re.findall('<li data-vid="(\d+)">', response.text)# 返回列表数据
for video_id in video_ids:# 通过for循环遍历 提取列表里面元素 一个一个提取
    # print(video_id) 

[*]发送请求, 把视频ID传入到视频数据包里面发送请求
[*]获取数据, 服务器返回数据内容
# f 字符串格式化方法 {} 占位符
video_info = f'https:// **** .com/moment/getMomentContent?videoId={video_id}&uid=&_=1647433310180'
json_data = requests.get(url=video_info, headers=headers).json()
# print(json_data)
# pprint.pprint(json_data)
# 根据冒号左边的内容, 提取冒号右边的内容 

[*]解析数据
title = json_data['data']['moment']['title']
video_url = json_data['data']['moment']['videoInfo']['definitions']['url'] 

[*]保存数据 >>> 发送请求 并且获取数据
video_content = requests.get(url=video_url, headers=headers).content
with open('video\\' + title + '.mp4', mode='wb') as f:
    f.write(video_content)
print(title, video_url) 
https://img-blog.csdnimg.cn/d02cf578313b43629b52526bce41e525.png
https://img-blog.csdnimg.cn/9ffaa592522345bbbff7e75fba3eefba.png
https://img-blog.csdnimg.cn/1016ab0cca6b4f04a9a1a0f65e20bb93.png
https://img-blog.csdnimg.cn/cde2cb741d8c4fb99a7e39cf45bda526.png
https://img-blog.csdnimg.cn/cc7d84952bbc4f64922c5c02438a4963.png
尾语
来源:https://www.cnblogs.com/hahaa/p/17253560.html
免责声明:由于采集信息均来自互联网,如果侵犯了您的权益,请联系我们【E-Mail:cb@itdo.tech】 我们会及时删除侵权内容,谢谢合作!
页: [1]
查看完整版本: Python:喜欢小姐姐?这不得来一波大采集?