ホームページ >バックエンド開発 >Python チュートリアル >Pythonで動画をダウンロードする方法
クロールする場合、多くの場合、ビデオをローカルに保存する必要があります。通常、最初にビデオ (.mp4) のダウンロード リンクを取得し、それからローカルに保存するパスを設定する必要があります (パスには姓
が含まれます。たとえば、次のようになります)。 D:/1.mp4)、関数によって渡されるパラメータは URL とパスです。
例: (推奨される学習: Python ビデオ チュートリアル )
import os,import requests。 def download_video(url, file_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(file_path): headers['Range'] = 'bytes=%d-' % os.path.getsize(file_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(file_path) and os.path.getsize(file_path) >= content_length): break pre_content_length = content_length # 写入收到的视频数据 with open(file_path, 'ab') as file: file.write(res.content) file.flush() print('receive data,file size : %d total size:%d' % (os.path.getsize(file_path), content_length)) except Exception as e: dic = {'url':url, 'file_path':file_path} print("下载失败:", dic)
ここではリクエストと OS ライブラリが使用されるため、OS のインポートとリクエストのインポートが必要です。
Python 関連の技術記事をさらに詳しく知りたい場合は、Python チュートリアル 列にアクセスして学習してください。
以上がPythonで動画をダウンロードする方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。