IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> Python知识库 -> Python爬取梨视频并下载【ajax抓包】 -> 正文阅读

[Python知识库]Python爬取梨视频并下载【ajax抓包】

涉及的知识点

  • 基础爬虫
  • 数据解析(xpath与正则表达式)
  • 多线程异步基础(线程池)
import requests
import os
import random
from lxml import etree
from multiprocessing.dummy import Pool
import re

headers={ 
           'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/80.0.3987.163 Safari/537.36'
}
url='https://www.pearvideo.com/category_5'
page_text=requests.get(url=url,headers=headers).content
#抓取初始界面
tree=etree.HTML(page_text)
li_list=tree.xpath('//*[@id="listvideoListUl"]/li[@class="categoryem "]')
urls=[]#储存信息
#储存路径
if not os.path.exists('./myvideos'):
    os.mkdir('./myvideos')

#每个视频界面
for li in li_list:
    v_name=li.xpath('./div/a/div[2]/text()')[0]+'.mp4'
    v_url='https://www.pearvideo.com/'+li.xpath('./div/a/@href')[0]
    v_page_text=requests.get(url=v_url,headers=headers).content
    v_tree=etree.HTML(v_page_text)
    
    #可发送请求的url
    #URL: https://www.pearvideo.com/videoStatus.jsp?contId=1752999&mrd=0.4515274121930508
    ajax_url='https://www.pearvideo.com/videoStatus.jsp?'
    #ajax动态抓取的界面
    ajax_id=str(v_tree.xpath('//*[@id="detailsbd"]/div[1]/div[2]/div/div[1]/div/div[1]/@data-id')[0])
    print('ajax_id:',ajax_id)
    params={
        'contId':ajax_id,
        'mrd':str(random.random())#0-1间的随机数值
    }
    ajax_headers={
            'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/80.0.3987.163 Safari/537.36',
            'Referer':'https://www.pearvideo.com/video_' +ajax_id
            #Referer记录跳转证明
    }

    dic_obj=requests.get(url=ajax_url,headers=ajax_headers,params=params).json()
    video_url=dic_obj["videoInfo"]["videos"]["srcUrl"]
    #伪地址 https://video.pearvideo.com/mp4/third/20220301/1646197798213-13293812-090123-hd.mp4
    #真地址 https://video.pearvideo.com/mp4/third/20220301/cont-1752999-13293812-090123-hd.mp4" 
    
    print('video_url:',video_url)#替换方式
    ex='.*?/third/{1}\d{8}/(.*?)-'
    word = re.findall(ex,video_url,re.S)[0]
    print('word:',word)
    new_video_url=re.sub(word,'cont-'+ajax_id,video_url)
    dic={
        'name':v_name,
        'url':new_video_url
    }
    urls.append(dic)

#将下载视频封装为函数
def get_video_data(dic_):
    url_=dic_['url']
    print(dic_['name'],'正在下载.....')
    v_data=requests.get(url=url_,headers=headers).content
    v_path='./myvideos/'+dic_['name']
    with open(v_path,'wb')as fp:
        fp.write(v_data)
        print(dic_['name'],'下载成功!')

pool=Pool(4)
pool.map(get_video_data,urls)
pool.close()
pool.join()

总结

  1. xpath在初始视频界面无法获取video的地址,可以查找network中是否是通过ajax请求动态获取。
  2. 注意 ajax请求的请求头中元素与params中元素来源。
    关于headers中referer的详解:https://www.jianshu.com/p/1a6abab212ed
  3. 注意到ajax请求到的video数据包中视频地址为假,与真地址对比并更改,学习re模块中通过正则表达式进行字符串替换。https://blog.csdn.net/zss041962/article/details/79089215
  Python知识库 最新文章
Python中String模块
【Python】 14-CVS文件操作
python的panda库读写文件
使用Nordic的nrf52840实现蓝牙DFU过程
【Python学习记录】numpy数组用法整理
Python学习笔记
python字符串和列表
python如何从txt文件中解析出有效的数据
Python编程从入门到实践自学/3.1-3.2
python变量
上一篇文章      下一篇文章      查看所有文章
加:2022-03-04 15:30:49  更:2022-03-04 15:31:25 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/10 13:36:08-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码