Warning: file_get_contents(/data/phpspider/zhask/data//catemap/0/windows/17.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
用Python解释ffmpeg输出_Python_Windows_Ffmpeg_Pycharm - Fatal编程技术网

用Python解释ffmpeg输出

用Python解释ffmpeg输出,python,windows,ffmpeg,pycharm,Python,Windows,Ffmpeg,Pycharm,我开始使用FFmpeg,我想创建一个列表,其中包含静默间隔的开始和结束时间戳。我确实使用FFmpeg打印出了这些间隔,但我需要格式化输出,使其看起来更可读,这就是为什么我想用它创建一个列表,然后使用自定义函数打印它。我知道我应该在这里使用正则表达式,但我不确定应该如何编写它,也不确定应该如何读取FFmpeg控制台输出。我的静音检测功能如下所示: def detect_silence_ffmpeg(): command = r"ffmpeg -i audio.wav -af silence

我开始使用FFmpeg,我想创建一个列表,其中包含静默间隔的开始和结束时间戳。我确实使用FFmpeg打印出了这些间隔,但我需要格式化输出,使其看起来更可读,这就是为什么我想用它创建一个列表,然后使用自定义函数打印它。我知道我应该在这里使用正则表达式,但我不确定应该如何编写它,也不确定应该如何读取FFmpeg控制台输出。我的静音检测功能如下所示:

def detect_silence_ffmpeg():
    command = r"ffmpeg -i audio.wav -af silencedetect=n=-40dB:d=0.5 -f null - "
    subprocess.call(command, shell=True)
该函数在7秒长的样本视频上的输出为:

ffmpeg version git-2020-06-03-b6d7c4c Copyright (c) 2000-2020 the FFmpeg developers
  built with gcc 9.3.1 (GCC) 20200523
  configuration: --enable-gpl --enable-version3 --enable-sdl2 --enable-fontconfig --enable-gnutls --enable-iconv --enable-libass --enable-libdav1d --enable-libbluray --enable-libfreetype --enable-libmp3lame --enable-libopencore-amrnb --enable-libopencore-amrwb --enable-libopenjpeg --enable-libopus --enable-libshine --enable-libsnappy --enable-libsoxr --enable-libsrt --enable-libtheora --enable-libtwolame --enable-libvpx --enable-libwavpack --enable-libwebp --enable-libx264 --enable-libx265 --enable-libxml2 --enable-libzimg --enable-lzma --enable-zlib --enable-gmp --enable-libvidstab --enable-libvmaf --enable-libvorbis --enable-libvo-amrwbenc --enable-libmysofa --enable-libspeex --enable-libxvid --enable-libaom --disable-w32threads --enable-libmfx --enable-ffnvcodec --enable-cuda-llvm --enable-cuvid --enable-d3d11va --enable-nvenc --enable-nvdec --enable-dxva2 --enable-avisynth --enable-libopenmpt --enable-amf
  libavutil      56. 49.100 / 56. 49.100
  libavcodec     58. 90.100 / 58. 90.100
  libavformat    58. 44.100 / 58. 44.100
  libavdevice    58.  9.103 / 58.  9.103
  libavfilter     7. 84.100 /  7. 84.100
  libswscale      5.  6.101 /  5.  6.101
  libswresample   3.  6.100 /  3.  6.100
  libpostproc    55.  6.100 / 55.  6.100
Guessed Channel Layout for Input Stream #0.0 : stereo
Input #0, wav, from 'audio.wav':
  Metadata:
    encoder         : Lavf58.44.100
  Duration: 00:00:07.34, bitrate: 1411 kb/s
    Stream #0:0: Audio: pcm_s16le ([1][0][0][0] / 0x0001), 44100 Hz, stereo, s16, 1411 kb/s
Stream mapping:
  Stream #0:0 -> #0:0 (pcm_s16le (native) -> pcm_s16le (native))
Press [q] to stop, [?] for help
Output #0, null, to 'pipe:':
  Metadata:
    encoder         : Lavf58.44.100
    Stream #0:0: Audio: pcm_s16le, 44100 Hz, stereo, s16, 1411 kb/s
    Metadata:
      encoder         : Lavc58.90.100 pcm_s16le
[silencedetect @ 00000202fc71e680] silence_start: 0
[silencedetect @ 00000202fc71e680] silence_end: 1.16374 | silence_duration: 1.16374
[silencedetect @ 00000202fc71e680] silence_start: 1.94558
[silencedetect @ 00000202fc71e680] silence_end: 3.41345 | silence_duration: 1.46787
[silencedetect @ 00000202fc71e680] silence_start: 3.8578
[silencedetect @ 00000202fc71e680] silence_end: 5.84844 | silence_duration: 1.99063
[silencedetect @ 00000202fc71e680] silence_start: 6.43653
size=N/A time=00:00:07.33 bitrate=N/A speed= 308x    
video:0kB audio:1264kB subtitle:0kB other streams:0kB global headers:0kB muxing overhead: unknown
[silencedetect @ 00000202fc71e680] silence_end: 7.33868 | silence_duration: 0.902154
这段代码应该在一个小时左右的视频上实现,所以我真的需要找到一种比这更好的格式。就这样,任何帮助都将不胜感激:)


注:我们的想法是,这应该主要适用于Windows,但如果跨平台也可行,那就太好了。

我找到了答案。可以做到以下几点:

command = r"ffmpeg -i audio.wav -af silencedetect=n=-40dB:d=0.5 -f null - "
out = subprocess.Popen(command, stdout=subprocess.PIPE, stderr=subprocess.STDOUT)

stdout, stderr = out.communicate()

这样,stdout变量将成为表示控制台上输出的字符串。当然,这需要导入子流程模块

你考虑过使用正则表达式吗?是的,我在帖子中写道,唯一让我困惑的是我应该如何在控制台上提取输出作为字符串或任何我可以实际应用正则表达式的东西。啊,我认为问题在于解析/解释。但这似乎不是问题所在