Python 视频合并工具

Python 视频合并工具

1.简介:

这是一个使用 moviepy 和 tkinter 创建的简单图形用户界面(GUI)应用程序,用于合并两个视频文件,并在两个视频之间添加淡入淡出过渡效果。程序的功能是:

  • 选择两个视频:用户可以选择两个视频文件,将它们合并成一个新的视频。
  • 过渡效果:在两个视频之间添加 1 秒钟的淡出淡入过渡效果,使合并后的视频更加平滑自然。
  • 输出视频:用户可以指定合并后视频的输出路径,并保存为 MP4 格式。

2.使用方法:

  • 选择视频文件:点击 "选择视频1" 和 "选择视频2" 按钮,选择需要合并的两个视频文件。
  • 设置输出路径:点击 "选择输出路径" 按钮,选择保存合并后视频的路径。
  • 合并视频:点击 "合并视频" 按钮,程序会合并两个视频,并添加 1 秒的淡入淡出过渡效果。合并完成后,会显示成功提示。

3.源码如下:

python 复制代码
import tkinter as tk
from tkinter import filedialog, messagebox
from moviepy.editor import VideoFileClip, concatenate_videoclips
 
 
# 定义合并视频的函数
def merge_videos_with_transition(video1_path, video2_path, output_path):
    try:
        # 加载两个视频
        video1 = VideoFileClip(video1_path).fadeout(1)  # 1秒淡出
        video2 = VideoFileClip(video2_path).fadein(1)  # 1秒淡入
 
        # 合并两个视频
        final_video = concatenate_videoclips([video1, video2], method="compose")
 
        # 输出合并后的视频
        final_video.write_videofile(output_path, codec="libx264", audio_codec="aac")
        messagebox.showinfo("成功", "视频合并成功!")
    except Exception as e:
        messagebox.showerror("错误", f"发生错误: {e}")
 
 
# 创建主窗口
root = tk.Tk()
root.title("视频合并工具")
 
# 设置窗口大小
root.geometry("400x300")
 
 
# 定义按钮点击事件,选择视频1文件
def select_video1():
    video1_path.set(filedialog.askopenfilename(filetypes=[("MP4 files", "*.mp4")]))
 
 
# 定义按钮点击事件,选择视频2文件
def select_video2():
    video2_path.set(filedialog.askopenfilename(filetypes=[("MP4 files", "*.mp4")]))
 
 
# 定义按钮点击事件,选择输出路径
def select_output():
    output_path.set(filedialog.asksaveasfilename(defaultextension=".mp4", filetypes=[("MP4 files", "*.mp4")]))
 
 
# 创建界面控件
video1_path = tk.StringVar()
video2_path = tk.StringVar()
output_path = tk.StringVar()
 
# 视频1选择框
tk.Label(root, text="选择第一个视频").pack(pady=10)
tk.Button(root, text="选择视频1", command=select_video1).pack(pady=5)
tk.Entry(root, textvariable=video1_path, width=50).pack(pady=5)
 
# 视频2选择框
tk.Label(root, text="选择第二个视频").pack(pady=10)
tk.Button(root, text="选择视频2", command=select_video2).pack(pady=5)
tk.Entry(root, textvariable=video2_path, width=50).pack(pady=5)
 
# 输出路径选择框
tk.Label(root, text="选择输出文件路径").pack(pady=10)
tk.Button(root, text="选择输出路径", command=select_output).pack(pady=5)
tk.Entry(root, textvariable=output_path, width=50).pack(pady=5)
 
# 合并按钮
tk.Button(root, text="合并视频",
          command=lambda: merge_videos_with_transition(video1_path.get(), video2_path.get(), output_path.get())).pack(
    pady=20)
 
# 启动 GUI 主循环
root.mainloop()
相关推荐
曲幽2 小时前
FastAPI压力测试实战:Locust模拟真实用户并发及优化建议
python·fastapi·web·locust·asyncio·test·uvicorn·workers
敏编程7 小时前
一天一个Python库:jsonschema - JSON 数据验证利器
python
前端付豪7 小时前
LangChain记忆:通过Memory记住上次的对话细节
人工智能·python·langchain
databook7 小时前
ManimCE v0.20.1 发布:LaTeX 渲染修复与动画稳定性提升
python·动效
花酒锄作田20 小时前
使用 pkgutil 实现动态插件系统
python
前端付豪1 天前
LangChain链 写一篇完美推文?用SequencialChain链接不同的组件
人工智能·python·langchain
曲幽1 天前
FastAPI实战:打造本地文生图接口,ollama+diffusers让AI绘画更听话
python·fastapi·web·cors·diffusers·lcm·ollama·dreamshaper8·txt2img
老赵全栈实战1 天前
Pydantic配置管理最佳实践(一)
python
阿尔的代码屋1 天前
[大模型实战 07] 基于 LlamaIndex ReAct 框架手搓全自动博客监控 Agent
人工智能·python
AI探索者2 天前
LangGraph StateGraph 实战:状态机聊天机器人构建指南
python