Lors du crawl, il est souvent nécessaire de sauvegarder les vidéos localement. Habituellement, vous devez d'abord obtenir le lien de téléchargement de la vidéo (.mp4), puis définir le chemin pour l'enregistrer localement (le chemin inclut le nom de famille,
, par exemple : D:/1.mp4), donc les paramètres transmis par la fonction sont l'url et le chemin.
Exemple : (Apprentissage recommandé : Tutoriel vidéo 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)
Les requêtes et les bibliothèques d'os sont utilisées ici, donc l'importation d'os et les requêtes d'importation sont requises.
Pour plus d'articles techniques liés à Python, veuillez visiter la colonne Tutoriel Python pour apprendre !
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!