本文分享给大家的是一款全网电影下载利器,采用requests库开发,支持下载各大网站的m3u8格式视频。
与一般下载工具不同,该工具具备强大的功能,能够完整地下载整个电影,并保存为mp4格式文件。
传统下载工具如IDM通常只能下载视频片段,而这款工具却能够轻松应对整部电影的下载需求。
安装 Python 库:
pip install requests tqdm
# 引入必要的库
import requests
import re
import json
from tqdm import tqdm
import shutil
from urllib.parse import urlparse
# 函数:获取网页标题
def fetch_page_title(url):
# 发送请求
response = requests.get(url)
# 判断响应状态是否为成功
if response.status_code == 200:
# 使用正则表达式匹配页面标题
match = re.search(r'<title>(.*?)</title>', response.text)
# 如果匹配成功,返回标题;否则返回默认值"video"
return match.group(1) if match else "video"
return "video"
# 函数:下载m3u8格式的视频
def download_video_m3u8(m3u8_url):
# 发送请求获取m3u8格式链接
response = requests.get(m3u8_url)
# 解析HTML内容
html = response.text
# 使用正则表达式匹配m3u8链接
pattern = r'([^"]+index\.m3u8)'
match = re.search(pattern, html)
# 解码链接中的特殊字符
decoded_url = json.loads('"' + match.group(1) + '"')
# 发送请求获取m3u8文件内容
m3u8_response = requests.get(decoded_url)
m3u8_data = m3u8_response.text
# 多层m3u8处理
match = re.search(r".*\.m3u8.*", m3u8_data)
if match:
lines = m3u8_data.split("\n")
s = lines[2]
decoded_url = decoded_url.replace("index.m3u8", s)
print("第二层链接:", decoded_url)
m3u8_response = requests.get(decoded_url)
m3u8_data = m3u8_response.text
# 提取.ts片段链接
segments = [line.strip() for line in m3u8_data.split('\n') if line.endswith('.ts')]
# 构建输出文件名
output_file = fetch_page_title(m3u8_url) + '.mp4'
print("电影名:", output_file)
print("电影链接:", decoded_url)
print("下载中...")
print("_"*30)
# 逐个下载.ts片段并写入文件
with open(output_file, 'wb') as f:
for segment in tqdm(segments):
segment_url = decoded_url.rsplit('/', 1)[0] + '/' + segment
segment_response = requests.get(segment_url, stream=True)
segment_response.raw.decode_content = True
shutil.copyfileobj(segment_response.raw, f)
# 下载完成提示
print("下载完成,保存到:" + output_file)
# 电影播放链接
m3u8_url = 'https://www.pian-ku.com/vodplay/179572-1-1/'
download_video_m3u8(m3u8_url)
注意事项说明:
-
在运行代码前,请确保已安装必要的库:requests, tqdm。
-
本代码用于下载在线视频,确保遵守相关法律法规,不要侵犯他人权益。
-
下载的视频文件保存在当前工作目录,确保有足够的磁盘空间。
-
网络环境良好时,下载可能较快,反之可能较慢,请耐心等待。