import requests
from moviepy.editor import VideoFileClip, AudioFileClip

if __name__ == '__main__':
    url = 'https://movie.douban.com/j/chart/top_list'
    param = {
        'type': '24',
        'interval_id': '100%3A90',
        'action': '',
        'start': '0',
        'limit': '10',
    }

    headers = {
        'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/99.0.4844.74 Safari/537.36 Edg/99.0.1150.55'
    }
    response = requests.get(url=url, params=param, headers=headers)

    list_data = response.json()

    for data in list_data:
        title = data['title']
        video_url = data['video_url']
        audio_url = data['audio_url']

        video_res = requests.get(video_url, headers=headers)
        with open('{}.mp4'.format(title), 'wb') as v_file:
            v_file.write(video_res.content)

        audio_res = requests.get(audio_url, headers=headers)
        with open('{}.mp3'.format(title), 'wb') as a_file:
            a_file.write(audio_res.content)

        video_clip = VideoFileClip('{}.mp4'.format(title))
        audio_clip = AudioFileClip('{}.mp3'.format(title))
        merge_result = video_clip.set_audio(audio_clip)
        merge_result.write_videofile('merge-{}.mp4'.format(title))

        os.remove('{}.mp4'.format(title))
        os.remove('{}.mp3'.format(title))

    print('视频合并完成!')

这段代码首先使用requests库获取豆瓣电影的预告片信息,包括视频和音频链接。然后,它分别下载视频和音频文件。最后,使用moviepy库将下载的视频和音频文件合并成一个完整的预告片。

代码解释:

  • requests.get(): 发送HTTP GET请求获取网页内容。
  • response.json(): 将JSON格式的响应数据解析为Python字典。
  • with open() as f: 打开文件并将文件对象赋值给f,在代码块结束后自动关闭文件。
  • VideoFileClip(): 加载视频文件。
  • AudioFileClip(): 加载音频文件。
  • set_audio(): 将音频添加到视频中。
  • write_videofile(): 将视频写入文件。
  • os.remove(): 删除文件。

通过学习这段代码,你可以了解到如何使用Python进行简单的网页爬取和视频处理。你可以尝试修改代码,例如更改下载的电影数量或类型,来自定义你的电影预告片下载器。

Python爬虫实战:使用requests和moviepy下载合并豆瓣电影预告片

原文地址: https://www.cveoy.top/t/topic/lawO 著作权归作者所有。请勿转载和采集!

免费AI点我,无需注册和登录