python基于http下载视频或音频
程序员文章站
2022-08-08 10:06:25
一、简介
这里介绍使用python基于http下载视频或音频。
二、关键点
1、断点续传
视频或音频文件一般比较大,所以通过需要断点续传。方式通过在http的hea...
一、简介
这里介绍使用python基于http下载视频或音频。
二、关键点
1、断点续传
视频或音频文件一般比较大,所以通过需要断点续传。方式通过在http的header里添加range字段,指示接下来需要接收文件的位置。
2、判断结束
这里采用读取response的content-length字段,若当前报文长度小于前次报文长度,或者已接收文件等于当前报文长度,则可以认为视频接收完成。
三、示例代码
import os import requests def do_load_media(url, path): try: headers = { "user-agent": "mozilla/5.0 (windows nt 6.2; wow64) applewebkit/537.36 (khtml, like gecko) maxthon/4.3.2.1000 chrome/30.0.1599.101 safari/537.36"} pre_content_length = 0 # 循环接收视频数据 while true: # 若文件已经存在,则断点续传,设置接收来需接收数据的位置 if os.path.exists(path): headers['range'] = 'bytes=%d-' % os.path.getsize(path) res = requests.get(url, stream=true, headers=headers) content_length = int(res.headers['content-length']) # 若当前报文长度小于前次报文长度,或者已接收文件等于当前报文长度,则可以认为视频接收完成 if content_length < pre_content_length or ( os.path.exists(path) and os.path.getsize(path) == content_length): break pre_content_length = content_length # 写入收到的视频数据 with open(path, 'ab') as file: file.write(res.content) file.flush() print('receive data,file size : %d total size:%d' % (os.path.getsize(path), content_length)) except exception as e: print(e) def load_media(): url = 'http://k.youku.com/player/getflvpath/sid/051446875256330ba12be_00/st/flv/fileid/030002080056eeca04f69a03baf2b1bbadca22-b1b9-e915-c03b-b0e7b0726c73?k=ae8e9a4d0f294dce282cef20&hd=0&myp=0&ts=377&ypp=0&ctype=30&ev=1&token=3759&oip=826403039&did=9e701e2baea8d466300184129d27d5d8&ep=aqahztjcifjag0w8go6bow3mo5jvcywrke5yfuq5zxod3kgns9wesh2xvfdztgomgcpdl%2bvjzd29guc%2bqedjfxcfxbphdiggvhdtkk064s9iv0vxt4b0xny39jlbh%2bck' path = r'e:/test.mp4' do_load_media(url, path) pass def main(): load_media() pass if __name__ == '__main__': main()
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
上一篇: JS控制上传文件个数
下一篇: 我不想和我爸一个下场