如何在Python中检查视频是否有声音?
如果视频有音频,我只想要如何在Python中检查视频是否有声音?,python,subprocess,ffprobe,Python,Subprocess,Ffprobe,如果视频有音频,我只想要True;如果没有音频,我想要False 我感觉使用子流程就快到了 我获取有关运行ffprobe并将结果拆分为列表的视频文件的信息。 我尝试过匹配列表中有或没有音频的字符串,但这并没有给我一致的结果 from subprocess import Popen, PIPE import subprocess b = '/path/to/mp4' '0:1' in str(subprocess.run(['ffprobe', b], stdout=PIPE, stderr=P
True
;如果没有音频,我想要False
我感觉使用子流程就快到了
我获取有关运行ffprobe
并将结果拆分为列表的视频文件的信息。我尝试过匹配列表中有或没有音频的字符串,但这并没有给我一致的结果
from subprocess import Popen, PIPE
import subprocess
b = '/path/to/mp4'
'0:1' in str(subprocess.run(['ffprobe', b], stdout=PIPE, stderr=PIPE).stderr.split()[-20])
上一行检查视频文件中最后一行的第20行是否有第二个流。就像我说的,并不总是一致的。我只是在请求或解析从
ffmprobe
获取的内容时遇到问题
这里是从ffprobe
返回的所有内容,而不是上一个项目的第20个
b = '/path/to/mp4'
subprocess.run(['ffprobe', b], stdout=PIPE, stderr=PIPE).stderr.split()
返回
[b'ffprobe',
b'version',
b'4.2.4-1ubuntu0.1',
b'Copyright',
b'(c)',
b'2007-2020',
b'the',
b'FFmpeg',
b'developers',
b'built',
b'with',
b'gcc',
b'9',
b'(Ubuntu',
b'9.3.0-10ubuntu2)',
b'configuration:',
b'--prefix=/usr',
b'--extra-version=1ubuntu0.1',
b'--toolchain=hardened',
b'--libdir=/usr/lib/x86_64-linux-gnu',
b'--incdir=/usr/include/x86_64-linux-gnu',
b'--arch=amd64',
b'--enable-gpl',
b'--disable-stripping',
b'--enable-avresample',
b'--disable-filter=resample',
b'--enable-avisynth',
b'--enable-gnutls',
b'--enable-ladspa',
b'--enable-libaom',
b'--enable-libass',
b'--enable-libbluray',
b'--enable-libbs2b',
b'--enable-libcaca',
b'--enable-libcdio',
b'--enable-libcodec2',
b'--enable-libflite',
b'--enable-libfontconfig',
b'--enable-libfreetype',
b'--enable-libfribidi',
b'--enable-libgme',
b'--enable-libgsm',
b'--enable-libjack',
b'--enable-libmp3lame',
b'--enable-libmysofa',
b'--enable-libopenjpeg',
b'--enable-libopenmpt',
b'--enable-libopus',
b'--enable-libpulse',
b'--enable-librsvg',
b'--enable-librubberband',
b'--enable-libshine',
b'--enable-libsnappy',
b'--enable-libsoxr',
b'--enable-libspeex',
b'--enable-libssh',
b'--enable-libtheora',
b'--enable-libtwolame',
b'--enable-libvidstab',
b'--enable-libvorbis',
b'--enable-libvpx',
b'--enable-libwavpack',
b'--enable-libwebp',
b'--enable-libx265',
b'--enable-libxml2',
b'--enable-libxvid',
b'--enable-libzmq',
b'--enable-libzvbi',
b'--enable-lv2',
b'--enable-omx',
b'--enable-openal',
b'--enable-opencl',
b'--enable-opengl',
b'--enable-sdl2',
b'--enable-libdc1394',
b'--enable-libdrm',
b'--enable-libiec61883',
b'--enable-nvenc',
b'--enable-chromaprint',
b'--enable-frei0r',
b'--enable-libx264',
b'--enable-shared',
b'libavutil',
b'56.',
b'31.100',
b'/',
b'56.',
b'31.100',
b'libavcodec',
b'58.',
b'54.100',
b'/',
b'58.',
b'54.100',
b'libavformat',
b'58.',
b'29.100',
b'/',
b'58.',
b'29.100',
b'libavdevice',
b'58.',
b'8.100',
b'/',
b'58.',
b'8.100',
b'libavfilter',
b'7.',
b'57.100',
b'/',
b'7.',
b'57.100',
b'libavresample',
b'4.',
b'0.',
b'0',
b'/',
b'4.',
b'0.',
b'0',
b'libswscale',
b'5.',
b'5.100',
b'/',
b'5.',
b'5.100',
b'libswresample',
b'3.',
b'5.100',
b'/',
b'3.',
b'5.100',
b'libpostproc',
b'55.',
b'5.100',
b'/',
b'55.',
b'5.100',
b'Input',
b'#0,',
b'mov,mp4,m4a,3gp,3g2,mj2,',
b'from',
b"'/media/iii/Q2/tor/Reddit/Subs/unexpected/l2aifial2ir51.mp4':",
b'Metadata:',
b'major_brand',
b':',
b'isom',
b'minor_version',
b':',
b'512',
b'compatible_brands:',
b'isomiso2avc1mp41',
b'encoder',
b':',
b'Lavf58.29.100',
b'Duration:',
b'00:00:16.27,',
b'start:',
b'0.000000,',
b'bitrate:',
b'1341',
b'kb/s',
b'Stream',
b'#0:0(und):',
b'Video:',
b'h264',
b'(Main)',
b'(avc1',
b'/',
b'0x31637661),',
b'yuv420p,',
b'384x480',
b'[SAR',
b'1:1',
b'DAR',
b'4:5],',
b'1205',
b'kb/s,',
b'30',
b'fps,',
b'30',
b'tbr,',
b'12k',
b'tbn,',
b'60',
b'tbc',
b'(default)',
b'Metadata:',
b'handler_name',
b':',
b'Bento4',
b'Video',
b'Handler',
b'Stream',
b'#0:1(und):',
b'Audio:',
b'aac',
b'(LC)',
b'(mp4a',
b'/',
b'0x6134706D),',
b'48000',
b'Hz,',
b'stereo,',
b'fltp,',
b'128',
b'kb/s',
b'(default)',
b'Metadata:',
b'handler_name',
b':',
b'Bento4',
b'Sound',
b'Handler']
我还尝试将此函数从一个返回视频文件持续时间的函数修改为一个返回音频True
或False
的函数,因为这可能是获取bool的一种不太老练的方法。我尝试使用这些不同的选项有点力不从心
def get_length(filename):
result = subprocess.run(["ffprobe", "-v", "error", "-show_entries",
"format=duration", "-of",
"default=noprint_wrappers=1:nokey=1", filename],
stdout=subprocess.PIPE,
stderr=subprocess.STDOUT)
return float(result.stdout)
答案并不难 雨衣
pip3安装ffprobe
窗户
pip安装ffprobe
LINUX
pip安装ffprobe
用法
ffprobe-show\u streams-print\u format json input.mov应该可以工作。答案并不难
雨衣
pip3安装ffprobe
窗户
pip安装ffprobe
LINUX
pip安装ffprobe
用法
ffprobe-show\u streams-print\u format json input.mov应该可以工作。我相信我找到了一个选项,可以对任何输出为1
(对于True
,有声音)或0
(对于False
,没有声音)的视频文件进行排序通过在下面的格式
选项中传递nb\u流
。
使用ffmpeg的和的组合来解决这个问题
def has_audio(filename):
result = subprocess.run(["ffprobe", "-v", "error", "-show_entries",
"format=nb_streams", "-of",
"default=noprint_wrappers=1:nokey=1", filename],
stdout=subprocess.PIPE,
stderr=subprocess.STDOUT)
return (int(result.stdout) -1)
代码实际上返回流的数量<代码>2
用于两个流,视频和音频,或1
仅用于视频。我减去了一个,因为我想得到布尔的答案。
这可能不应用于对仅音频文件进行排序。尽管我想知道,对于已知的视频文件,是否仅视频文件的1
、音频和视频文件的2
。一个视频文件可以有3个或更多的流吗?我相信我找到了一个选项,可以对任何输出为1
(对于True
,有声音)或0
(对于False
,没有声音)的视频文件进行排序,方法是在下面的格式
选项中传递nbu流
。
使用ffmpeg的和的组合来解决这个问题
def has_audio(filename):
result = subprocess.run(["ffprobe", "-v", "error", "-show_entries",
"format=nb_streams", "-of",
"default=noprint_wrappers=1:nokey=1", filename],
stdout=subprocess.PIPE,
stderr=subprocess.STDOUT)
return (int(result.stdout) -1)
代码实际上返回流的数量<代码>2
用于两个流,视频和音频,或1
仅用于视频。我减去了一个,因为我想得到布尔的答案。这可能不应用于对仅音频文件进行排序。尽管我想知道,对于已知的视频文件,是否仅视频文件的
1
、音频和视频文件的2
。一个视频文件可以有3个或更多的流吗?基于前面的答案,这将检查每个流,看看是否至少有一个流具有“音频”类型的编解码器。请注意,音频流可能存在但没有声音,在这种情况下,仍将返回True
from subprocess import check_output
import json
def has_audio_streams(file_path):
command = ['ffprobe', '-show_streams',
'-print_format', 'json', file_path]
output = check_output(command)
parsed = json.loads(output)
streams = parsed['streams']
audio_streams = list(filter((lambda x: x['codec_type'] == 'audio'), streams))
return len(audio_streams) > 0
基于前面的答案,这将检查每个流,以查看是否至少有一个流具有“音频”类型的编解码器。请注意,音频流可能存在但没有声音,在这种情况下,仍将返回True
from subprocess import check_output
import json
def has_audio_streams(file_path):
command = ['ffprobe', '-show_streams',
'-print_format', 'json', file_path]
output = check_output(command)
parsed = json.loads(output)
streams = parsed['streams']
audio_streams = list(filter((lambda x: x['codec_type'] == 'audio'), streams))
return len(audio_streams) > 0
这回答了你的问题吗?似乎更多的是使用ffprobe的正确参数的问题,而不是Python的问题。@mkrieger1谢谢,但不完全是。这是用于“使用ffprobe检查仅音频文件”。而且,它似乎不适合Python。它很有用,如果我花一两个小时来破解它,我可能会从这个答案中得到我想要的。@mkrieger1“对于ffprobe而不是Python问题”,我只是使用ffprobe,因为这是我尝试过的。我知道最好不要在没有发布尝试的情况下就StackOverflow提出问题。我需要检查一个视频是否有Python音频。使用或不使用ffprobe,但使用Python。不是命令行。答案中显示的命令告诉您文件是有视频还是音频,在这两种情况下都有效。它返回一个JSON数据结构,可以用Python轻松解析,请参阅。这是否回答了您的问题?似乎更多的是使用ffprobe的正确参数的问题,而不是Python的问题。@mkrieger1谢谢,但不完全是。这是用于“使用ffprobe检查仅音频文件”。而且,它似乎不适合Python。它很有用,如果我花一两个小时来破解它,我可能会从这个答案中得到我想要的。@mkrieger1“对于ffprobe而不是Python问题”,我只是使用ffprobe,因为这是我尝试过的。我知道最好不要在没有发布尝试的情况下就StackOverflow提出问题。我需要检查一个视频是否有Python音频。使用或不使用ffprobe,但使用Python。不是命令行。答案中显示的命令告诉您文件是有视频还是音频,在这两种情况下都有效。它返回一个JSON数据结构,可以用Python轻松解析,请参阅。谢谢。但是在Python中呢?我试图将其应用到子流程中,比如so
subprocess.run([“ffprobe”、“-show\u streams”、“-print\u format”、“json”,b],stdout=PIPE,stderr=PIPE)
,但Python说类型仍然是子流程。CompletedProcess
。谢谢。但是在Python中呢?我试图将其应用到子流程中,如sosubprocess.run([“ffprobe”、“-show_streams”、“-print_format”、“json”,b]、stdout=PIPE、stderr=PIPE)
但Python说类型仍然是subprocess.CompletedProcess
。是的,视频文件可以有3个以上的流(例如,多种语言的音频曲目)。感谢提供了有用的Python包装器分解!是的,视频文件可以有