python整合ffmpeg实现视频文件的批量转换
转换工具层出不穷,ffmpeg才是全能的转换工具,只是不支持图形操作。
没有关系,命令行方式,在freebsd/linux下直接来
我们的思路是,设定一个文件夹存放源视频文件,python读取该文件夹下的全部文件,并对文件通过ffmpeg进行分析,根据需要,修改目标文件的编码、分辨率等等,调用ffmpeg转换。
我这次的需求是,我家液晶电视只支持分辨来,长宽均小于720,编码只支持divx/xvid的avi文件,且fps只能小于25——多次实践,才总结出来的,电视说明书也没说!!
下面的程序将
/root//root2/video/origin
下存在的全部文件转换成液晶电视需要的avi格式电影
以下是最新的修改,引入了OptionParser 参数分析工具。能指定最大宽度,音视频编码,视频质量,原路径,目的路径,工作路径等
# coding=gb2312 import string import os import time import re import sys from optparse import OptionParser parser = OptionParser() #parser.add_option("-i", "--input", dest="input",action="store_true",help="input x y for each file by user") parser.add_option("-q", "--quality", dest="q",action="store",help="input xvid q arg",default="24") parser.add_option("-v", "--vcodec", dest="vcodec",action="store",help="input video codec",default="x264") parser.add_option("-n", "--noaudio", dest="an",action="store_true",help="no audio") parser.add_option("-p", "--preset", dest="preset",action="store",help="",default="") parser.add_option("-m", "--maxWidth", dest="maxWidth",action="store",help="input max width for output video",default="") parser.add_option("-f", "--fileType", dest="fileType",action="store",help="",default="mp4") parser.add_option("-o", "--ogg", dest="ogg",action="store_true",help="user ogg instead of aac",default="") parser.add_option("-3", "--mp3", dest="mp3",action="store_true",help="user mp3 instead of aac",default="") parser.add_option("-1", "--pad", dest="pad",action="store_true",help="pad to 16:9",default="") parser.add_option("-s", "--src", dest="srcD",action="store",help="source dir",default="/usr/disk2/root/video/origin") parser.add_option("-t", "--target", dest="targetD",action="store",help="target dir",default="/usr/disk2/root/video/ok") parser.add_option("-w", "--workdir", dest="workdir",action="store",help="work dir",default="/root/root2/video") (options, args) = parser.parse_args() if options.srcD==None or options.srcD[0:1]=='-': print 'srcD Err, quit' exit() if options.targetD==None or options.targetD[0:1]=='-': print 'targetD Err, quit' exit() if options.fileType==None or options.fileType[0:1]=='-': print 'fileType Err, quit' exit() if options.workdir==None or options.workdir[0:1]=='-': print 'workdir Err, quit' exit() #遍历origin下的文件 for root,dirs,files in os.walk(options.srcD): for name in files: name= name.replace('[','''\[''')#对文件名中的[进行转义 newname =name[0: name.rindex('.')] #运行一次ffmpeg,获取分辨率 (si, so, se) = os.popen3('cd '+options.workdir+';mkdir -p ffm; rm -f ffm/ffm.txt ; csh -c "(ffmpeg -i '+options.srcD+'/' +name+ ' >& ffm/ffm.txt)"; grep Stream ffm/ffm.txt') t=so.readlines() ti=0 for line in se.readlines() : print line width=0 height=0 reg='''^\s*Stream.*,\s*(\d+)x(\d+)(?: \[SAR|,)''' #Stream #0.0: Video: RV40 / 0x30345652, 1020x572, 23 fps, 23 tbr, 23 tbn, 23 tbc for line in t: result = re.compile(reg).findall(line) for c in result: print name+' '+c[0] + 'x' + c[1] width=string.atoi(c[0]) height=string.atoi(c[1]) if name[0:3]=='M2U' and width==720 and height==576:#m2U开头的,宽度是720x576的,是4:3存储16:9的,将其转换为16:9 width=1024 if width==0: print 'error parsing width and height' exit() vc='' qstr='' astr='' vpre='' s='' if options.maxWidth!='': if width>string.atoi(options.maxWidth): height = height * string.atoi(options.maxWidth) / width width = string.atoi(options.maxWidth) padStr='' if options.pad==True: if height*16/9 - width>10:#宽度不够 padStr=' -vf "pad='+str(height*16/9)+':'+str(height)+':'+str((height*16/9 - width)/2)+':0:black"' elif width - height*16/9 >10:#高度不够 padStr=' -vf "pad='+str(width)+':'+str(width*9/16)+':0:'+str((width - height*16/9)/2)+':black"' s=' -s '+str(width)+'x'+str(height)+padStr print 'adjust',s if options.preset!='': vpre=' -vpre '+options.preset if options.an==True: astr=' -an' elif options.ogg==True: astr=' -acodec libvorbis -ar 44100 -ab 64K' elif options.mp3==True: astr=' -acodec libmp3lame -ar 44100 -ab 64K' else: astr=' -acodec libfaac -ar 44100 -ab 64K' if options.vcodec=='vp8': vc='libvpx' qstr=" -qmin "+options.q+" -qmax "+options.q elif options.vcodec=='x264': vc='libx264' qstr=" -crf "+options.q elif options.vcodec=='xvid': vc='libxvid' qstr=" -qmin "+options.q+" -qmax "+options.q cmd ='csh -c "' + "cd "+options.workdir+";touch ffm/output.log;(ffmpeg -y -i "+options.srcD+"/"+name+astr+" -vcodec "+vc+vpre+qstr+s+" -r 25 -threads 8 "+options.targetD+"/"+newname+"."+options.fileType + ' >>& ffm/output.log)"' print cmd #运行 (si, so, se) = os.popen3(cmd) for line in se.readlines() :#打印输出 print line for line in so.readlines() :#打印输出 print line #print cmd,' finish'#再显示一次命令
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
- ffmpeg+Python实现B站MP4格式音频与视频的合并示例代码
- Python3 ffmpeg视频转换工具使用方法解析
- python ffmpeg任意提取视频帧的方法
- python opencv 读取本地视频文件 修改ffmpeg的方法
- python利用ffmpeg进行录制屏幕的方法
- Python3.6.2调用ffmpeg的方法
- python+ffmpeg批量去视频开头的方法
- 利用python和ffmpeg 批量将其他图片转换为.yuv格式的方法
- python+ffmpeg视频并发直播压力测试
- python调用系统ffmpeg实现视频截图、http发送
- Python调用ffmpeg开源视频处理库,批量处理视频
相关文章
Python爬虫模拟登陆哔哩哔哩(bilibili)并突破点选验证码功能
这篇文章主要介绍了Python爬虫模拟登陆哔哩哔哩(bilibili)并突破点选验证码功能,本文通过图文实例相结合给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下2020-12-12
最新评论