微信扫码
添加专属顾问
我要投稿
这是关于用 Python 和 ffmpeg 批量合并 ts 视频片段的实用指南,值得一看! 核心内容: 1. 合并视频的具体步骤 2. 首次运行未成功的反馈 3. 可能导致失败的原因及解决方案
Deepseek中输入提示词:
写一个Python脚本,打开这些文件夹:
E:\avideo\Batty
读取里面的子文件夹:index,里面是很多ts视频片段,将这些ts片段按顺序合并成一个完整的视频文件,可以使用ffmpeg进行转码和合并;
合并后的视频文件格式为mp4,保存到文件夹:E:\aivideo
然后删除掉ts视频;
注意:每一步都要输出信息到屏幕上
Deepseek给出源代码,但是第一次运行程序没有成功,
给deepseek反馈:合并视频没有成功,文件夹里面是空的,反思下问题在哪里
Deepseek的回复:
在合并视频时遇到问题,文件夹为空,可能有以下几个原因导致合并失败。我们需要逐步排查并修正问题。
可能的原因及解决方案:
ffmpeg未正确安装或未在系统路径中
问题:如果ffmpeg未安装或未添加到系统环境变量中,Python脚本无法调用ffmpeg命令。
解决方案:
检查ffmpeg是否安装:
bash
复制
ffmpeg -version
如果未安装,请从FFmpeg官网下载并安装。
确保ffmpeg已添加到系统环境变量中:
在Windows中,将ffmpeg的安装路径(如C:\ffmpeg\bin)添加到系统的Path环境变量中。
在Python脚本中测试ffmpeg是否可用:
python
复制
import subprocess
try:
subprocess.run(["ffmpeg", "-version"], check=True)
print("ffmpeg 已正确安装。")
except FileNotFoundError:
print("ffmpeg 未找到,请检查安装和路径配置。")
.ts文件路径问题
问题:如果.ts文件的路径中包含特殊字符(如中文、空格、引号等),ffmpeg可能无法正确读取文件。
解决方案:
在生成file_list.txt时,确保文件路径被正确转义。
修改脚本中的文件列表生成逻辑,确保路径被单引号包裹:
python
复制
with open(file_list_path, "w", encoding="utf-8") as file_list:
for ts_file in ts_files:
file_list.write(f"file '{os.path.join(index_folder, ts_file)}'\n")
.ts文件未按正确顺序排序
问题:如果.ts文件的命名不规范,可能导致文件顺序错误,合并后的视频内容混乱或失败。
解决方案:
确保.ts文件按正确的顺序排序。可以通过文件名中的数字部分排序:
python
复制
ts_files.sort(key=lambda x: int(x.split(".")[0])) # 假设文件名是数字开头,如 1.ts, 2.ts
如果文件名不是纯数字,需要根据实际命名规则调整排序逻辑。
ffmpeg命令参数问题
问题:ffmpeg的命令参数可能不正确,导致合并失败。
解决方案:
确保ffmpeg命令正确。可以使用以下命令测试:
bash
复制
ffmpeg -f concat -safe 0 -i file_list.txt -c copy output.mp4
如果仍然失败,尝试使用-vsync vfr参数:
python
复制
ffmpeg_command = [
"ffmpeg", "-f", "concat", "-safe", "0", "-i", file_list_path, "-c", "copy", "-vsync", "vfr", output_video
]
权限问题
问题:如果脚本没有权限读取.ts文件或写入输出文件夹,可能导致合并失败。
解决方案:
确保脚本以管理员权限运行。
检查文件夹和文件的权限,确保脚本可以访问和修改它们。
调试输出
问题:如果脚本没有输出详细的错误信息,难以定位问题。
解决方案:
在subprocess.run中捕获并输出ffmpeg的错误信息:
python
复制
result = subprocess.run(ffmpeg_command, capture_output=True, text=True)
if result.returncode != 0:
print("ffmpeg 合并失败,错误信息:")
print(result.stderr)
else:
print("ffmpeg 合并成功。")
修正后的完整脚本
以下是修正后的脚本,包含上述改进和调试信息:
import os
import subprocess
# 定义文件夹路径
folders = [
r"E:\avideo\Batty"
]
# 输出文件夹
output_folder = r"E:\aivideo"
# 确保输出文件夹存在
if not os.path.exists(output_folder):
os.makedirs(output_folder)
print(f"创建输出文件夹: {output_folder}")
# 遍历每个文件夹
for folder in folders:
index_folder = os.path.join(folder, "index")
# 检查index文件夹是否存在
if os.path.exists(index_folder):
print(f"正在处理文件夹: {index_folder}")
# 获取所有的.ts文件
ts_files = [f for f in os.listdir(index_folder) if f.endswith('.ts')]
ts_files.sort(key=lambda x: int(x.split(".")[0])) # 按文件名排序
# 生成文件列表
file_list_path = os.path.join(index_folder, "file_list.txt")
with open(file_list_path, "w", encoding="utf-8") as file_list:
for ts_file in ts_files:
file_list.write(f"file '{os.path.join(index_folder, ts_file)}'\n")
print(f"生成文件列表: {file_list_path}")
# 生成输出视频文件名
output_video = os.path.join(output_folder, os.path.basename(folder) + ".mp4")
# 使用ffmpeg合并视频
ffmpeg_command = [
"ffmpeg", "-f", "concat", "-safe", "0", "-i", file_list_path, "-c", "copy", output_video
]
print(f"正在合并视频: {output_video}")
result = subprocess.run(ffmpeg_command, capture_output=True, text=True)
if result.returncode != 0:
print("ffmpeg 合并失败,错误信息:")
print(result.stderr)
else:
print("ffmpeg 合并成功。")
# 删除.ts文件
for ts_file in ts_files:
os.remove(os.path.join(index_folder, ts_file))
print(f"删除文件: {os.path.join(index_folder, ts_file)}")
# 删除文件列表
os.remove(file_list_path)
print(f"删除文件列表: {file_list_path}")
print(f"完成处理文件夹: {index_folder}")
else:
print(f"文件夹 {index_folder} 不存在,跳过处理。")
print("所有文件夹处理完成。")
关键修正点
字符串闭合:
确保所有f-string都正确闭合,例如:
python
复制
print(f"删除文件列表: {file_list_path}")
如果字符串中包含特殊字符(如中文),确保使用正确的引号。
文件路径处理:
使用os.path.join来拼接路径,避免手动拼接路径时出错。
使用os.path.exists检查文件夹是否存在。
调试信息:
在subprocess.run中捕获ffmpeg的输出和错误信息,便于排查问题。
测试运行
确保ffmpeg已正确安装并可用。
运行脚本,观察输出信息。
如果合并失败,检查ffmpeg的错误信息并调整脚本。
运行这个修改后的源代码,成功合并ts视频。
53AI,企业落地大模型首选服务商
产品:场景落地咨询+大模型应用平台+行业解决方案
承诺:免费场景POC验证,效果验证后签署服务协议。零风险落地应用大模型,已交付160+中大型企业
2024-09-04
2024-09-26
2024-10-30
2025-01-25
2024-09-03
2024-10-30
2024-12-25
2024-12-11
2024-09-06
2024-08-18