mirror of https://github.com/sgoudham/Enso-Bot.git
Adding FFMpeg
parent
37ee8b3988
commit
ed40a1f2ed
@ -0,0 +1 @@
|
||||
pip
|
@ -0,0 +1,14 @@
|
||||
Metadata-Version: 2.1
|
||||
Name: ffmpeg
|
||||
Version: 1.4
|
||||
Summary: ffmpeg python package url [https://github.com/jiashaokun/ffmpeg]
|
||||
Home-page: https://github.com/jiashaokun/ffmpeg
|
||||
Author: SkeyJIA
|
||||
Author-email: 363604236@qq.com
|
||||
License: MIT Licence
|
||||
Keywords: python ffmpeg
|
||||
Platform: any
|
||||
|
||||
ffmpeg python package
|
||||
|
||||
|
@ -0,0 +1,15 @@
|
||||
ffmpeg-1.4.dist-info/INSTALLER,sha256=zuuue4knoyJ-UwPPXg8fezS7VCrXJQrAP7zeNuwvFQg,4
|
||||
ffmpeg-1.4.dist-info/METADATA,sha256=mQ--kqbm0FFb1TRADa3ROWnL4fDGQhBop6KFKC1PEq4,301
|
||||
ffmpeg-1.4.dist-info/RECORD,,
|
||||
ffmpeg-1.4.dist-info/WHEEL,sha256=YUYzQ6UQdoqxXjimOitTqynltBCkwY6qlTfTh2IzqQU,97
|
||||
ffmpeg-1.4.dist-info/top_level.txt,sha256=z628G4f1qm1oii2XkgEn5nrm9Po8Lc5pEIqe96eodlk,7
|
||||
ffmpeg/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
||||
ffmpeg/__pycache__/__init__.cpython-36.pyc,,
|
||||
ffmpeg/__pycache__/audio.cpython-36.pyc,,
|
||||
ffmpeg/__pycache__/image.cpython-36.pyc,,
|
||||
ffmpeg/__pycache__/stream.cpython-36.pyc,,
|
||||
ffmpeg/__pycache__/video.cpython-36.pyc,,
|
||||
ffmpeg/audio.py,sha256=vkIadwpzBmHCtkstUIa90ZvFHW5QmPtuUvc9Uqep-TU,1600
|
||||
ffmpeg/image.py,sha256=L-pEJ-3-6Muqwu83wzIMqP5sSOqBHXViNNfsUe8ONk4,1187
|
||||
ffmpeg/stream.py,sha256=t1MDGSUdVxvTCjICuPzNVXHU4Ht3mJgQpqF3a9Fnd7o,6477
|
||||
ffmpeg/video.py,sha256=Gg7l4KM7_oQUvfAIWO1vrB3tMjDeiPBg2ouHwgKLG_o,8471
|
@ -0,0 +1,5 @@
|
||||
Wheel-Version: 1.0
|
||||
Generator: bdist_wheel (0.34.2)
|
||||
Root-Is-Purelib: true
|
||||
Tag: py3-none-any
|
||||
|
@ -0,0 +1 @@
|
||||
ffmpeg
|
@ -0,0 +1,60 @@
|
||||
#!/usr/local/bin/python3
|
||||
|
||||
import subprocess
|
||||
|
||||
|
||||
# 调整音频播放速率
|
||||
def a_speed(input_file, speed, out_file):
|
||||
try:
|
||||
cmd = "ffmpeg -y -i %s -filter_complex \"atempo=tempo=%s\" %s" % (input_file, speed, out_file)
|
||||
res = subprocess.call(cmd, shell=True)
|
||||
|
||||
if res != 0:
|
||||
return False
|
||||
return True
|
||||
except Exception:
|
||||
return False
|
||||
|
||||
|
||||
# 音频截取 str_second 开始时间秒数 intercept 截取长度秒。从开始时间截取多少秒的音频
|
||||
def a_intercept(input_file, str_second, duration, out_file):
|
||||
try:
|
||||
cmd = "ffmpeg -y -i %s -ss %s -t %s %s" % (input_file, str_second, duration, out_file)
|
||||
res = subprocess.call(cmd, shell=True)
|
||||
|
||||
if res != 0:
|
||||
return False
|
||||
return True
|
||||
except Exception:
|
||||
return False
|
||||
|
||||
|
||||
# 音频拼接 input_file_list = ["1.mp3", "2.mp3"]
|
||||
def a_split(input_file_list, out_file):
|
||||
try:
|
||||
if len(input_file_list) < 2:
|
||||
return False
|
||||
split_str = "|"
|
||||
a_list = split_str.join(input_file_list)
|
||||
|
||||
cmd= "ffmpeg -y -i \"concot:%s\" %s" % (a_list, out_file)
|
||||
res = subprocess.call(cmd, shell=True)
|
||||
|
||||
if res != 0:
|
||||
return False
|
||||
return True
|
||||
except Exception:
|
||||
return False
|
||||
|
||||
|
||||
# 调整音量大小
|
||||
def a_volume(input_file, volume, out_file):
|
||||
try:
|
||||
cmd = "ffmpeg -y -i %s -af volume=%s %s" % (input_file, volume, out_file)
|
||||
res = subprocess.call(cmd, shell=True)
|
||||
|
||||
if res != 0:
|
||||
return False
|
||||
return True
|
||||
except Exception:
|
||||
return False
|
@ -0,0 +1,50 @@
|
||||
#!/usr/local/bin/python3
|
||||
# module sys
|
||||
|
||||
import subprocess
|
||||
|
||||
|
||||
# png 转 gif
|
||||
def img_trans_gif(png_list, out_file):
|
||||
try:
|
||||
cmd = "ffmpeg -f image2 -i %s -y %s" % (png_list, out_file)
|
||||
res = subprocess.call(cmd, shell=True)
|
||||
|
||||
if res != 0:
|
||||
return False
|
||||
return True
|
||||
except Exception:
|
||||
return False
|
||||
|
||||
|
||||
# png 转 视频
|
||||
def img_trans_video(png_list, duration, out_file):
|
||||
try:
|
||||
cmd = "ffmpeg -loop 1 -f image2 -i %s -t %s -vcodec libx264 -y %s" % (png_list, duration, out_file)
|
||||
res = subprocess.call(cmd, shell=True)
|
||||
|
||||
if res != 0:
|
||||
return False
|
||||
return True
|
||||
except Exception:
|
||||
return False
|
||||
|
||||
|
||||
# gif 转 图片
|
||||
def gif_trans_img(input_file, out_path, img_prefix, category="png"):
|
||||
try:
|
||||
if out_path == "":
|
||||
return False
|
||||
out_path = out_path.rstrip("/")
|
||||
img = img_prefix + "_%d"
|
||||
|
||||
out_img = "%s/%s.%s" % (out_path, img, category)
|
||||
cmd = "ffmpeg -y -i %s %s" % (input_file, out_img)
|
||||
|
||||
res = subprocess.call(cmd, shell=True)
|
||||
|
||||
if res != 0:
|
||||
return False
|
||||
return True
|
||||
except Exception:
|
||||
return False
|
@ -0,0 +1,215 @@
|
||||
#!/usr/bin/python2.7
|
||||
# coding=utf-8
|
||||
|
||||
import os
|
||||
|
||||
import json
|
||||
|
||||
import subprocess
|
||||
|
||||
|
||||
class Stream(object):
|
||||
def __init__(self):
|
||||
self.cmd = ""
|
||||
self.out_file = ""
|
||||
self.vcode_type = ""
|
||||
self.input_file = ""
|
||||
self.word_list_str = ""
|
||||
self.subbtitle_file = ""
|
||||
|
||||
self.cmd = []
|
||||
self.img_file = []
|
||||
self.word_list = []
|
||||
self.img_dynamic_list = []
|
||||
|
||||
self.image_list = {}
|
||||
self.dynamic_list = {}
|
||||
|
||||
# 输入文件
|
||||
def input(self, file):
|
||||
self.input_file = file
|
||||
|
||||
# 添加图片
|
||||
def img(self, img, x="0", y="0", str_time="0", end_time="0"):
|
||||
if img == "":
|
||||
return False
|
||||
input_info = self.video_info()
|
||||
|
||||
if end_time == "0":
|
||||
end_time = float(input_info["format"]["duration"]) + 10.0
|
||||
|
||||
img_data = {
|
||||
"img": img,
|
||||
"x": str(x),
|
||||
"y": str(y),
|
||||
"str_time": str(str_time),
|
||||
"end_time": str(end_time)
|
||||
}
|
||||
|
||||
self.img_file.append(img_data)
|
||||
|
||||
img_input = []
|
||||
img_overlay = []
|
||||
|
||||
for val in self.img_file:
|
||||
img_input.append(" -i %s" % val["img"])
|
||||
img_overlay.append(" overlay=x=%s:y=%s:enable='if(gt(t,%s),lt(t,%s))" % (
|
||||
val["x"],
|
||||
val["y"],
|
||||
val["str_time"],
|
||||
val["end_time"]
|
||||
)
|
||||
)
|
||||
|
||||
img_input_str = " ".join(img_input)
|
||||
img_overlay_str = ",".join(img_overlay)
|
||||
|
||||
self.image_list = {
|
||||
"input": img_input_str,
|
||||
"overlay": img_overlay_str
|
||||
}
|
||||
|
||||
# 添加动态图片 gif apng 等
|
||||
def img_dynamic(self, file, x="0", y="0", str_time="0", end_time="0"):
|
||||
input_info = self.video_info()
|
||||
if file == "":
|
||||
return False
|
||||
if end_time == "":
|
||||
end_time = float(input_info["format"]["duration"]) + 10.0
|
||||
|
||||
apng = {
|
||||
"input": " -ignore_loop 0 -i %s" % file,
|
||||
"x": str(x),
|
||||
"y": str(y),
|
||||
"str_time": str(str_time),
|
||||
"end_time": str(end_time)
|
||||
}
|
||||
self.img_dynamic_list.append(apng)
|
||||
|
||||
img_dy_input = []
|
||||
img_dy_overlay = []
|
||||
for val in self.img_dynamic_list:
|
||||
img_dy_input.append(val["input"])
|
||||
img_dy_overlay.append(" overlay=x=%s:y=%s:shortest=1:enable='if(gt(t,%s), lt(t,%s))'" % (
|
||||
val["x"],
|
||||
val["y"],
|
||||
val["str_time"],
|
||||
val["end_time"]
|
||||
)
|
||||
)
|
||||
img_dy_input_str = " ".join(img_dy_input)
|
||||
img_dy_overlay_str = ",".join(img_dy_overlay)
|
||||
|
||||
self.dynamic_list = {
|
||||
"input": img_dy_input_str,
|
||||
"overlay": img_dy_overlay_str
|
||||
}
|
||||
|
||||
# 添加文字水印
|
||||
def word_water_mark(self, c, x="0", y="0", str_time="0", end_time="0", font="", color="white"):
|
||||
if font == "":
|
||||
return False
|
||||
input_info = self.video_info()
|
||||
if c == "":
|
||||
return False
|
||||
if end_time == "0":
|
||||
end_time = float(input_info["format"]["duration"]) + 10.0
|
||||
|
||||
text = " drawtext=text='%s':x=%s:y=%s:enable='if(gt(t,%s),lt(t,%s))':fontfile=%s:" \
|
||||
"fontcolor=%s" % (c, str(x), str(y), str(str_time), str(end_time), str(font), str(color))
|
||||
self.word_list.append(text)
|
||||
|
||||
self.word_list_str = ",".join(self.word_list)
|
||||
|
||||
# 添加字幕文件 subtitles=txt.srt
|
||||
def subbtitle(self, file):
|
||||
self.subbtitle_file = " subtitles=%s" % file
|
||||
|
||||
# 编码方式 -vcodec
|
||||
def vcode(self, code):
|
||||
if code == "":
|
||||
return False
|
||||
self.vcode_type = " -vcodec %s" % code
|
||||
|
||||
# 输出文件
|
||||
def out(self, file):
|
||||
if file == "":
|
||||
return False
|
||||
self.out_file = "%s" % file
|
||||
|
||||
# 执行脚本
|
||||
def run(self):
|
||||
if self.input_file == "":
|
||||
return False
|
||||
im = "ffmpeg -i %s" % self.input_file
|
||||
ov = ""
|
||||
|
||||
if len(self.dynamic_list) > 0 and self.dynamic_list["input"] != "":
|
||||
im = "%s %s" % (im, self.dynamic_list["input"])
|
||||
|
||||
if ov != "":
|
||||
ov = "%s,%s" % (ov, self.dynamic_list["overlay"])
|
||||
else:
|
||||
ov = self.dynamic_list["overlay"]
|
||||
if len(self.image_list) > 0:
|
||||
im = "%s %s" % (im, self.image_list["input"])
|
||||
|
||||
if ov != "":
|
||||
ov = "%s,%s" % (ov, self.dynamic_list["overlay"])
|
||||
else:
|
||||
ov = self.dynamic_list["overlay"]
|
||||
|
||||
# 文字水印
|
||||
if self.word_list_str != "":
|
||||
if ov != "":
|
||||
ov = "%s,%s" % (ov, self.word_list_str)
|
||||
else:
|
||||
ov = self.word_list_str
|
||||
|
||||
# 字幕
|
||||
if self.subbtitle_file != "":
|
||||
if ov != "":
|
||||
ov = "%s,%s" % (ov, self.subbtitle_file)
|
||||
else:
|
||||
ov = self.subbtitle_file
|
||||
|
||||
if self.vcode_type != "":
|
||||
self.cmd = "%s -filter_complex \"%s\" -y %s %s" % (im, ov, self.vcode_type, self.out_file)
|
||||
else:
|
||||
self.cmd = "%s -filter_complex \"%s\" -y %s" % (im, ov, self.out_file)
|
||||
|
||||
self.do()
|
||||
|
||||
# 获取视频的相关时长信息
|
||||
def video_info(self):
|
||||
result = {}
|
||||
if os.path.isfile(self.input_file) is False:
|
||||
return result
|
||||
|
||||
cmd = ['ffprobe', '-v', 'quiet', '-print_format', 'json', '-show_format', '-show_streams', self.input_file]
|
||||
returned_data = subprocess.check_output(cmd)
|
||||
return json.loads(returned_data.decode('utf-8'))
|
||||
|
||||
# 执行命令
|
||||
def do(self):
|
||||
if self.cmd == "":
|
||||
return False
|
||||
res = subprocess.call(self.cmd, shell=True)
|
||||
if res != 0:
|
||||
return False
|
||||
return True
|
||||
|
||||
|
||||
if __name__ == '__main__':
|
||||
stream = Stream()
|
||||
stream.input("face.mp4")
|
||||
stream.img("t1.png")
|
||||
stream.img("t2.png", "10", y=10, str_time=5, end_time=10)
|
||||
stream.img_dynamic("t1.apng", x=10, y=10, str_time=5, end_time=10)
|
||||
stream.img_dynamic("t2.apng", x=10, y=10, str_time=5, end_time=9)
|
||||
stream.word_water_mark("测试文字水印1", x="10", y="10", str_time="0", end_time="20", font="ttf.ttf", color="white")
|
||||
stream.word_water_mark("测试文字水印2", x="10", y="10", str_time="0", end_time="20", font="ttf.ttf", color="white")
|
||||
stream.subbtitle("srt.srt")
|
||||
stream.out("out.mp4")
|
||||
stream.run()
|
||||
|
@ -0,0 +1,302 @@
|
||||
#!/usr/local/bin/python3
|
||||
# module sys
|
||||
|
||||
|
||||
import subprocess
|
||||
|
||||
|
||||
def ins_img(input_file, img_data, out_file):
|
||||
try:
|
||||
if len(img_data) <= 0:
|
||||
return False
|
||||
|
||||
img_list = []
|
||||
img_list_str = " -i "
|
||||
png_complex = []
|
||||
complex_png_str = ","
|
||||
|
||||
for img in img_data:
|
||||
if len(img["x"]) == 0:
|
||||
img["x"] = "0"
|
||||
|
||||
if len(img["y"]) == 0:
|
||||
img["y"] = "0"
|
||||
img_list.append(img["img"])
|
||||
|
||||
if len(img["str_time"]) > 0:
|
||||
if len(img["end_time"]) > 0:
|
||||
cmp_str = "overlay=x=%s:y=%s:enable='if(gt(t,%s),lt(t,%s))'" % (img["x"], img["y"], img["str_time"], img["end_time"])
|
||||
else:
|
||||
cmp_str = "overlay=x=%s:y=%s:enable='if(gt(t,%s))'" % (img["x"], img["y"], img["str_time"])
|
||||
else:
|
||||
cmp_str = "overlay=x=%s:y=%s" % (img["x"], img["y"])
|
||||
|
||||
png_complex.append(cmp_str)
|
||||
|
||||
img_str_list = img_list_str.join(img_list)
|
||||
complex_png_str = complex_png_str.join(png_complex)
|
||||
|
||||
cmd = "ffmpeg -i %s -i %s -filter_complex \"%s\" -y %s" % (input_file, img_str_list, complex_png_str, out_file)
|
||||
|
||||
res = subprocess.call(cmd, shell=True)
|
||||
|
||||
if res != 0:
|
||||
return False
|
||||
return True
|
||||
|
||||
except Exception:
|
||||
return False
|
||||
|
||||
|
||||
# 视频添加动图 gif apng
|
||||
def ins_dynamic_img(input_file, img_data, out_file):
|
||||
try:
|
||||
if img_data["img"] == "":
|
||||
return False
|
||||
|
||||
if img_data["x"] == "":
|
||||
img_data["x"] = 0
|
||||
|
||||
if img_data["y"] == "":
|
||||
img_data["y"] = 0
|
||||
|
||||
if img_data["str_time"] != "":
|
||||
if img_data["end_time"] != "":
|
||||
comp = "overlay=x=%s:y=%s:shortest=1:enable='if(gt(t,%s), lt(t,%s))'" % (img_data["x"], img_data["y"],
|
||||
img_data["str_time"],
|
||||
img_data["end_time"])
|
||||
else:
|
||||
comp = "overlay=x=%s:y=%s:shortest=1:enable='if(gt(t,%s)'" % (img_data["x"], img_data["y"],
|
||||
img_data["str_time"])
|
||||
else:
|
||||
comp = "overlay=x=%s:y=%s:shortest=1"
|
||||
|
||||
cmd = "ffmpeg -i %s -ignore_loop 0 -i %s -filter_complex \"%s\" -y %s" % (input_file, img_data["img"], comp,
|
||||
out_file)
|
||||
|
||||
res = subprocess.call(cmd, shell=True)
|
||||
|
||||
if res != 0:
|
||||
return False
|
||||
return True
|
||||
except Exception:
|
||||
return False
|
||||
|
||||
|
||||
# 视频静音 分离音频流
|
||||
|
||||
def separate_audio(input_file, out_file):
|
||||
try:
|
||||
cmd = "ffmpeg -y -i %s -vcodec copy -an %s" % (input_file, out_file)
|
||||
res = subprocess.call(cmd, shell=True)
|
||||
|
||||
if res != 0:
|
||||
return False
|
||||
return True
|
||||
except Exception:
|
||||
return False
|
||||
|
||||
|
||||
# 视频静音 使用静音帧 为视频静音
|
||||
def video_ins_mute_audio(input_file, mute_mp3_file, out_file):
|
||||
try:
|
||||
cmd = "ffmpeg -y -i %s -filter_complex '[1:0]apad' -shortest %s" % (input_file, mute_mp3_file, out_file)
|
||||
res = subprocess.call(cmd, shell=True)
|
||||
|
||||
if res != 0:
|
||||
return False
|
||||
return True
|
||||
except Exception:
|
||||
return False
|
||||
|
||||
|
||||
# 视频设置分辨率 及 码率
|
||||
def trans_code(input_file, width, height, rate, out_file):
|
||||
try:
|
||||
cmd = "ffmpeg -y -i %s -s %sx%s -b %sk -acodec copy %s" % (input_file, width, height, rate, out_file)
|
||||
res = subprocess.call(cmd, shell=True)
|
||||
|
||||
if res != 0:
|
||||
return False
|
||||
return True
|
||||
except Exception:
|
||||
return False
|
||||
|
||||
|
||||
# 视频添加弹幕
|
||||
def ins_barrage(input_file, barrage, out_file):
|
||||
try:
|
||||
if len(barrage) == 0:
|
||||
return False
|
||||
|
||||
bag = []
|
||||
bag_str = ", "
|
||||
vf_str = ""
|
||||
|
||||
for val in barrage:
|
||||
if val["fontsize"] == "":
|
||||
val["fontsize"] = 40
|
||||
|
||||
if val["fontcolor"] == "":
|
||||
val["fontcolor"] = "white"
|
||||
|
||||
if val["y"] == "":
|
||||
val["y"] = "100"
|
||||
|
||||
if val["str_time"] == "":
|
||||
val["str_time"] = 0
|
||||
else:
|
||||
val["str_time"] = int(val["str_time"])
|
||||
|
||||
if val["speet"] == "":
|
||||
val["speet"] = 150
|
||||
else:
|
||||
val["speet"] = int(val["speet"])
|
||||
|
||||
txt = "drawtext=text='%s':fontcolor=%s:fontsize=%s:fontfile=%s:y=%s:x=w-(t-%d)*%d:enable='gte(t,%d)'" % (
|
||||
val["context"],
|
||||
val["fontcolor"],
|
||||
val["fontsize"],
|
||||
val["fontfile"],
|
||||
val["y"],
|
||||
val["str_time"],
|
||||
val["speet"],
|
||||
val["str_time"]
|
||||
)
|
||||
bag.append(txt)
|
||||
|
||||
vf_str = bag_str.join(bag)
|
||||
|
||||
cmd = "ffmpeg -y -i %s -vf \"%s\" %s" % (input_file, vf_str, out_file)
|
||||
res = subprocess.call(cmd, shell=True)
|
||||
|
||||
if res != 0:
|
||||
return False
|
||||
return True
|
||||
except Exception:
|
||||
return False
|
||||
|
||||
|
||||
# 调整视频速率 speed 小于 1 减速,大于 1 加速 1 等速
|
||||
def playback_speed(input_file, speed, out_file):
|
||||
try:
|
||||
if speed == "":
|
||||
speed = "1"
|
||||
cmd = "ffmpeg -y -i %s -filter_complex \"setpts=PTS/%s\" %s" % (input_file, speed, out_file)
|
||||
res = subprocess.call(cmd, shell=True)
|
||||
|
||||
if res != 0:
|
||||
return False
|
||||
return True
|
||||
|
||||
except Exception:
|
||||
return False
|
||||
|
||||
|
||||
# 视频倒放 ( 视频 + 音频 )
|
||||
def a_v_reverse(input_file, out_file):
|
||||
try:
|
||||
cmd = "ffmpeg -y -i %s -vf vf reverse -af areverse %s " % (input_file, out_file)
|
||||
res = subprocess.call(cmd, shell=True)
|
||||
|
||||
if res != 0:
|
||||
return False
|
||||
return True
|
||||
except Exception:
|
||||
return False
|
||||
|
||||
|
||||
# 视频倒放 (视频)
|
||||
def v_reverse(input_file, out_file):
|
||||
try:
|
||||
cmd = "ffmpeg -y -i %s -vf vf reverse %s " % (input_file, out_file)
|
||||
res = subprocess.call(cmd, shell=True)
|
||||
|
||||
if res != 0:
|
||||
return False
|
||||
return True
|
||||
except Exception:
|
||||
return False
|
||||
|
||||
|
||||
# 视频截取 截取 duration 时长的视频 从 str_second 开始截取
|
||||
def v_intercept(input_file, str_second, duration, out_file):
|
||||
try:
|
||||
cmd = "ffmpeg -y -i %s -ss %s -t %s -f mp4 %s" % (input_file, str_second, duration, out_file)
|
||||
res = subprocess.call(cmd, shell=True)
|
||||
|
||||
if res != 0:
|
||||
return False
|
||||
return True
|
||||
except Exception:
|
||||
return False
|
||||
|
||||
|
||||
# 视频合并 严格模式 文件协议合并
|
||||
def strict_v_merge(input_file, out_file):
|
||||
try:
|
||||
cmd = "ffmpeg -y -f concat -safe 0 -i %s -acodec copy %s" % (input_file, out_file)
|
||||
res = subprocess.call(cmd, shell=True)
|
||||
|
||||
if res != 0:
|
||||
return False
|
||||
return True
|
||||
except Exception:
|
||||
return False
|
||||
|
||||
|
||||
# 视频合并 有损模式 input_file_list = ["1.mp4", "2.ts", "3.flv"]
|
||||
def damage_v_merge(input_file_list, out_file):
|
||||
try:
|
||||
if len(input_file_list) < 2:
|
||||
return False
|
||||
|
||||
video = []
|
||||
video_n = len(input_file_list)
|
||||
video_str = " -i "
|
||||
|
||||
comp_list = []
|
||||
comp_str = " "
|
||||
i = 0
|
||||
for val in input_file_list:
|
||||
video.append(val)
|
||||
v_str = "[%s:a][%s:v]" % (i, i)
|
||||
comp_list.append(v_str)
|
||||
|
||||
i += 1
|
||||
|
||||
video_list = video_str.join(video)
|
||||
com_list_str = comp_str.join(comp_list)
|
||||
|
||||
cmd = "ffmpeg -y -i %s -filter_complex \"%s concat=n=%d:v=1:a=1\" -vcodec h264_nvenc %s" % (
|
||||
video_list,
|
||||
com_list_str,
|
||||
video_n,
|
||||
out_file
|
||||
)
|
||||
|
||||
res = subprocess.call(cmd, shell=True)
|
||||
|
||||
if res != 0:
|
||||
return False
|
||||
return True
|
||||
except Exception:
|
||||
return False
|
||||
|
||||
|
||||
# 视频转 图片
|
||||
def video_trans_img(input_file, out_path, img_prefix, category="png"):
|
||||
try:
|
||||
out_path = out_path.rstrip("/")
|
||||
img = img_prefix + "_%d"
|
||||
|
||||
out_img = "%s/%s.%s" % (out_path, img, category)
|
||||
cmd = "ffmpeg -i %s -f image2 %s" % (input_file, out_img)
|
||||
|
||||
res = subprocess.call(cmd, shell=True)
|
||||
|
||||
if res != 0:
|
||||
return False
|
||||
return True
|
||||
except Exception:
|
||||
return False
|
Loading…
Reference in New Issue