代码示例

# coding=utf-8

import os

import subprocess

import datetime

import json, pprint

import re, time

import threading

import random

import shutil

class FFmpeg:

def __init__(self, editvdo, addlogo=None, addmusic=None,

addvdohead=None, addvdotail=None):

self.editvdo = editvdo

self.addlogo = addlogo

self.addmusic = addmusic

self.addvdohead = addvdohead

self.addvdotail = addvdotail

self.vdo_time, self.vdo_width, self.vdo_height, self.attr_dict = self.get_attr()

self.editvdo_path = os.path.dirname(editvdo)

self.editvdo_name = os.path.basename(editvdo)

def get_attr(self):

"""

获取视频属性参数

:return:

"""

strcmd = r'ffprobe -print_format json -show_streams -i "{}"'.format(self.editvdo)

status, output = subprocess.getstatusoutput(strcmd)

agrs = eval(re.search('{.*}', output, re.S).group().replace("\n", "").replace(" ", ''))

streams = agrs.get('streams', [])

agrs_dict = dict()

[agrs_dict.update(x) for x in streams]

vdo_time = agrs_dict.get('duration')

vdo_width = agrs_dict.get('width')

vdo_height = agrs_dict.get('height')

attr = (vdo_time, vdo_width, vdo_height, agrs_dict)

return attr

def edit_head(self, start_time, end_time, deposit=None):

"""

截取指定长度视频

:param second: 去除开始的多少秒

:param deposit: 另存为文件

:return: True/Flase

"""

if None == deposit:

deposit = self.editvdo_path+'/'+'edit_head'+self.editvdo_name

start = time.strftime('%H:%M:%S', time.gmtime(start_time))

end = time.strftime('%H:%M:%S', time.gmtime(end_time))

strcmd = 'ffmpeg -i "{}" -vcodec copy -acodec copy -ss {} -to {} "{}" -y'.format(

self.editvdo, start, end, deposit)

result = subprocess.run(args=strcmd, stdout=subprocess.PIPE, shell=True)

if os.path.exists(deposit):

os.remove(self.editvdo)

os.rename(deposit, self.editvdo)

return True

else:

return False

def edit_logo(self, deposit=None):

"""

添加水印

:param deposit:添加水印后另存为路径,为空则覆盖

:return: True/False

"""

if None == deposit:

deposit = self.editvdo_path+'/'+'edit_logo'+self.editvdo_name

strcmd = r'ffmpeg -i "{}" -vf "movie=\'{}\' [watermark];[in] ' \

r'[watermark] overlay=main_w-overlay_w-10:10 [out]" "{}"'.format(

self.editvdo, self.addlogo, deposit)

result = subprocess.run(args=strcmd, stdout=subprocess.PIPE, shell=True)

if os.path.exists(deposit):

os.remove(self.editvdo)

os.rename(deposit, self.editvdo)

return True

else:

return False

def edit_music(self, deposit=None):

if None == deposit:

deposit = self.editvdo_path+'/'+'edit_music'+self.editvdo_name

strcmd = r'ffmpeg -y -i "{}" -i "{}" -filter_complex "[0:a] ' \

r'pan=stereo|c0=1*c0|c1=1*c1 [a1], [1:a] ' \

r'pan=stereo|c0=1*c0|c1=1*c1 [a2],[a1][a2]amix=duration=first,' \

r'pan=stereo|c0

r'-map "[a]" -map 0:v -c:v libx264 -c:a aac ' \

r'-strict -2 -ac 2 "{}"'.format(self.editvdo, self.addmusic, deposit)

result = subprocess.run(args=strcmd, stdout=subprocess.PIPE, shell=True)

if os.path.exists(deposit):

os.remove(self.editvdo)

os.rename(deposit, self.editvdo)

return True

else:

return False

def edit_rate(self, rete=30, deposit=None):

"""

改变帧率

:param rete: 修改大小帧率

:param deposit: 修改后保存路径

:return:

"""

if None == deposit:

deposit = self.editvdo_path+'/'+'edit_music'+self.editvdo_name

strcmd = r'ffmpeg -i "{}" -r {} "{}"' % (self.editvdo, rete, deposit)

result = subprocess.run(args=strcmd, stdout=subprocess.PIPE, shell=True)

if os.path.exists(deposit):

os.remove(self.editvdo)

os.rename(deposit, self.editvdo)

return True

else:

return False

def edit_power(self, power='1280x720', deposit=None):

"""

修改分辨率

:param power: 分辨率

:param deposit: 修改后保存路径,为空则覆盖

:return:

"""

if None == deposit:

deposit = self.editvdo_path+'/'+'edit_power'+self.editvdo_name

strcmd = r'ffmpeg -i "{}" -s {} "{}"'.format(self.editvdo, power, deposit)

result = subprocess.run(args=strcmd, stdout=subprocess.PIPE, shell=True)

if os.path.exists(deposit):

os.remove(self.editvdo)

os.rename(deposit, self.editvdo)

return True

else:

return False

def rdit_marge(self, vdo_head, vdo_tail, deposit=None):

if None == deposit:

deposit = self.editvdo_path+'/'+'rdit_marge'+self.editvdo_name

with open(self.editvdo_path+'/'+'rdit_marge.txt', 'w', encoding='utf-8') as f:

f.write("file '{}' \nfile '{}' \nfile '{}'" .format(

vdo_head, self.editvdo, vdo_tail))

strcmd = r'ffmpeg -f concat -safe 0 -i "{}" -c copy "{}"'.format(

self.editvdo_path + '/' + 'rdit_marge.txt', deposit)

result = subprocess.run(args=strcmd, stdout=subprocess.PIPE, shell=True)

if os.path.exists(deposit):

os.remove(self.editvdo)

os.rename(deposit, self.editvdo)

return True

else:

return False

# ffmpeg - i input.mkv - filter_complex "[0:v]setpts=0.5*PTS[v];[0:a]atempo=2.0[a]" - map"[v]" - map"[a]" output.mkv

test = FFmpeg(r"D:\vdio\4.mp4")

pass

移动端设备除iPad Pro外,其它移动设备仅能阅读基础的文本文字。

建议使用PC或笔记本电脑,本站暂不支持微软IE/Edge浏览器,推荐使用Chrome或FireFox进行浏览,以开启左侧互动实验区来提升学习效率,推荐使用的分辨率为1920x1080或更高。

我们坚信最好的学习是参与其中这一理念,并致力成为中文互联网上体验更好的学练一体的IT技术学习交流平台。

您可加QQ群:575806994,一起学习交流技术,反馈网站使用中遇到问题。

内容、课程、广告等相关商务合作请扫描右侧二维码添加好友。

Copyright 2020 FreeAIHub.com

网站备案号:京ICP备19043805号

收藏本站

python批量处理视频_Python调用ffmpeg开源视频处理库,批量处理视频相关推荐

  1. python视频处理加速的库_Python调用ffmpeg开源视频处理库,批量处理视频

    代码示例 # coding=utf-8 import os import subprocess import datetime import json, pprint import re, time ...

  2. 2023-02-21:请用go语言调用ffmpeg,解码mp4文件,输出视频信息和总帧数。

    2023-02-21:请用go语言调用ffmpeg,解码mp4文件,输出视频信息和总帧数. 答案2023-02-21: 使用 github.com/moonfdd/ffmpeg-go 库,这个库比go ...

  3. java命令截图,GitHub - xuege-cn/fmj: FMJ (FFMpeg for Java)。通过Java调用FFMpeg命令的方式来对音视频进行处理(获取信息、截图等等)。...

    项目介绍 FMJ (FFMpeg for Java) 通过Java调用FFMpeg命令的方式来对音视频进行处理(获取信息.截图等等). FFMpeg安装 建议使用 ffmpeg-2.6.1 版本 Li ...

  4. python截取视频_python使用ffmpeg截取视频段

    下载ffmpeg的压缩包,直接解压 建议采用python+ffmpeg截取视频段,但是当视频文件路径含中文时出错,中文乱码.Python用subprocess调用乱码问题. 解决方法:视频文件路径编码 ...

  5. python调用opencv处理视频_Python调用OpenCV读写视频

    最近因为经常对视频进行操作,所以记录下Python用opencv来读写视频的方法. 一.opencv读视频 python调用opencv来读视频比较简单,可以直接调用cv2.VideoCapture来 ...

  6. java在线制作视频,调用ffmpeg(一)

    目地:写一个java制作视频的网站. 大致流程:用户上传n张图片和背景音乐,网站返回一个视频. 大家都知道,java是通过命令行来调用ffmpeg的,java没有现成的比较好的封装ffmpeg的jar ...

  7. java在线制作视频,调用ffmpeg(具备影大师、爱美客在线制作视频等功能)

    最近在学校准备一个乡土文化教育竞赛项目,大部分的项目交互都是采用的论坛的形式展现,我打算采用视频交互的形式,针对于大部分人群,他们没有视频制作基础,视频制作对于他们来说太过于困难,为了服务这部分人群, ...

  8. python 方法的实例_python调用自定义函数的实例操作

    在python中,想要调用自定义函数必须先声明,然后才能调用.使用函数时,只要按照函数定义的形式,向函数传递必需的参数,就可以调用函数完成相应的功能或者获得函数返回的处理结果. (1)声明函数 pyt ...

  9. python爬微信公众号视频_python爬虫公众号所有信息,并批量下载公众号视频

    之前写过一篇类似的文章:python爬取公众号,用最简单的方式爬虫 还有同学一直在问,可能中间有一些小细节不明确,这次彻底明确一下细节. 本篇添加一个批量下载公众号内视频的功能,可以实现完全复制一个公 ...

最新文章

  1. SAP IDES、DEV、QAS、PRD都是什么含义
  2. C# mvc 500 内部服务器访问异常
  3. antd 中table上加不同字体颜色_字体渲染系统!微软终于决定优化Win10字体模糊问题...
  4. 饼状图改变数据显示位置_这么用MatPlotLib视觉化呈现数据,你值得拥有
  5. ASP.NETCore编程实现基本认证
  6. ant.design pro 登录模块分析
  7. Maven项目:Spring Boot版本的办公自动化系统
  8. 思科模拟器基础实验完整流程-初级
  9. 网页上腾讯视频下载mp4格式到本地
  10. 如何获取腾讯应用appid
  11. 论文笔记:多标签学习——LIFT算法
  12. Open Feign调用出现CRTL CODE 31两种解决方案
  13. html 复选框 不能编辑,javascript-jqGrid-复选框编辑无法编辑所选行
  14. 2.1.3 毫米波雷达
  15. 操作系统面试、复试问答题
  16. 软件汉化:关于.net软件汉化流程说明
  17. 计算机常用计量单位,计量符号-计算机中的有些计量单位例如G、MB是表示什 – 手机爱问...
  18. matlab绘制单摆相图,单摆相图绘制
  19. 星盘软件测试自学,腾讯星座频道_占星知识大讲堂
  20. 融合遗传算法与XGBoost的玉米百粒重相关基因挖掘

热门文章

  1. Python小白教学系列 | 字典
  2. 信息文明时代之西方文明历史的重构谭
  3. U.S.News2020世界大学排行榜新鲜出炉
  4. 浏览器[包含360浏览器]输入框自动填充问题
  5. LeanTouch 案例分享
  6. 随笔记录 松下烘干洗衣机门打不开怎么处理
  7. 关于gym新版本0.23.0版本的一些问题以及Box2D的安装
  8. 长春长生们究竟卖到了哪里去?
  9. Ubuntu安装fsl
  10. nodejs虾米音乐批量下载某个歌手的专辑