动态网页抓取( Python小二如何使用python实现抓取腾讯视频所有电影,本文通过实例代码)

优采云 发布时间: 2022-04-16 19:17

  动态网页抓取(

Python小二如何使用python实现抓取腾讯视频所有电影,本文通过实例代码)

  Python实现抓取腾讯视频所有电影的示例代码

  更新时间:2022-04-16 13:40:22 作者:Python小二

  本篇文章主要介绍如何使用python捕捉腾讯视频的所有电影。本文通过示例代码为您介绍了一个非常详细的示例代码,具有一定的参考价值。有需要的朋友可以参考以下

  内容

  运行环境实现目的和思考目的

  实现腾讯视频目标url的解析下载。由于第三方vip解析,只提供在线观看,隐藏目标视频下载。

  想法

  先获取你想看的腾讯电影的url,通过第三方vip视频解析网站,抓包,模拟浏览器发送正常请求,获取缓存的ts文件,下载video ts文件,最后通过Convert to mp4文件正常播放

  完整代码

  

import re

import os,shutil

import requests,threading

from urllib.request import urlretrieve

from pyquery import PyQuery as pq

from multiprocessing import Pool

'''

'''

class video_down():

def __init__(self,url):

# 拼接全民解析url

self.api='https://jx.618g.com'

self.get_url = 'https://jx.618g.com/?url=' + url

#设置UA模拟浏览器访问

self.head = {'User-Agent': 'Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/63.0.3239.132 Safari/537.36'}

#设置多线程数量

self.thread_num=32

#当前已经下载的文件数目

self.i = 0

# 调用网页获取

html = self.get_page(self.get_url)

if html:

# 解析网页

self.parse_page(html)

def get_page(self,get_url):

try:

print('正在请求目标网页....',get_url)

response=requests.get(get_url,headers=self.head)

if response.status_code==200:

#print(response.text)

print('请求目标网页完成....\n 准备解析....')

self.head['referer'] = get_url

return response.text

except Exception:

print('请求目标网页失败,请检查错误重试')

return None

def parse_page(self,html):

print('目标信息正在解析........')

doc=pq(html)

self.title=doc('head title').text()

print(self.title)

url = doc('#player').attr('src')[14:]

html=self.get_m3u8_1(url).strip()

#self.url = url + '800k/hls/index.m3u8'

self.url = url[:-10] +html

print(self.url)

print('解析完成,获取缓存ts文件.........')

self.get_m3u8_2(self.url)

def get_m3u8_1(self,url):

try:

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

html=response.text

print('获取ts文件成功,准备提取信息')

return html[-20:]

except Exception:

print('缓存文件请求错误1,请检查错误')

def get_m3u8_2(self,url):

try:

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

html=response.text

print('获取ts文件成功,准备提取信息')

self.parse_ts_2(html)

except Exception:

print('缓存文件请求错误2,请检查错误')

def parse_ts_2(self,html):

pattern=re.compile('.*?(.*?).ts')

self.ts_lists=re.findall(pattern,html)

print('信息提取完成......\n准备下载...')

self.pool()

def pool(self):

print('经计算需要下载%d个文件' % len(self.ts_lists))

self.ts_url = self.url[:-10]

if self.title not in os.listdir():

os.makedirs(self.title)

print('正在下载...所需时间较长,请耐心等待..')

#开启多进程下载

pool=Pool(16)

pool.map(self.save_ts,[ts_list for ts_list in self.ts_lists])

pool.close()

pool.join()

print('下载完成')

self.ts_to_mp4()

def ts_to_mp4(self):

print('ts文件正在进行转录mp4......')

str='copy /b '+self.title+'\*.ts '+self.title+'.mp4'

os.system(str)

filename=self.title+'.mp4'

if os.path.isfile(filename):

print('转换完成,祝你观影愉快')

shutil.rmtree(self.title)

def save_ts(self,ts_list):

try:

ts_urls = self.ts_url + '{}.ts'.format(ts_list)

self.i += 1

print('当前进度%d/%d'%(self.i,len(self.ts_lists)))

urlretrieve(url=ts_urls, filename=self.title + '/{}.ts'.format(ts_list))

except Exception:

print('保存文件出现错误')

if __name__ == '__main__':

#电影目标url:狄仁杰之四大天王

url='https://v.qq.com/x/cover/r6ri9qkcu66dna8.html'

#电影*敏*感*词*5:神秘国度

url1='https://v.qq.com/x/cover/5c58griiqftvq00.html'

#电视剧斗破苍穹

url2='https://v.qq.com/x/cover/lcpwn26degwm7t3/z0027injhcq.html'

url3='https://v.qq.com/x/cover/33bfp8mmgakf0gi.html'

video_down(url2)

  视频缓存ts文件

  这里有一些缓存的视频文件,每个只播放几秒钟。最后需要合并成一个mp4格式的视频,才能正常播放。默认高清下载

  注意这里的进度仅供参考,因为使用了多进程下载。进度未准确显示。可以进入文件夹查看正常进度。可以理解为显示一次进度,下载一个ts文件。

  达到效果

  

  以上是Python抓取腾讯所有视频的示例代码的详细内容。更多关于Python抓拍腾讯视频的信息,请关注德牛网其他相关话题文章!

0 个评论

要回复文章请先登录注册


官方客服QQ群

微信人工客服

QQ人工客服


线