gpt4 book ai didi

audio - 使用 FFMPEG 和静音检测来消除音频静音

转载 作者:行者123 更新时间:2023-12-03 14:31:59 24 4
gpt4 key购买 nike

我正在尝试将以下命令与最新的 ffmpeg 版本一起使用,以从我的 .mp3 文件中删除静音:

ffmpeg -i SILENCE.mp3 -af silencedetect=n=-50dB:d=1 -y -ab 192k  SILENCE_OUT.mp3

但是,会产生以下输出:
ffmpeg version N-66154-g1654ca7 Copyright (c) 2000-2014 the FFmpeg developers
built on Sep 5 2014 22:10:38 with gcc 4.8.3 (GCC)
configuration: --enable-gpl --enable-version3 --disable-w32threads --enable-av
isynth --enable-bzlib --enable-fontconfig --enable-frei0r --enable-gnutls --enab
le-iconv --enable-libass --enable-libbluray --enable-libbs2b --enable-libcaca --
enable-libfreetype --enable-libgme --enable-libgsm --enable-libilbc --enable-lib
modplug --enable-libmp3lame --enable-libopencore-amrnb --enable-libopencore-amrw
b --enable-libopenjpeg --enable-libopus --enable-librtmp --enable-libschroedinge
r --enable-libsoxr --enable-libspeex --enable-libtheora --enable-libtwolame --en
able-libvidstab --enable-libvo-aacenc --enable-libvo-amrwbenc --enable-libvorbis
--enable-libvpx --enable-libwavpack --enable-libwebp --enable-libx264 --enable-
libx265 --enable-libxavs --enable-libxvid --enable-decklink --enable-zlib
libavutil 54. 7.100 / 54. 7.100
libavcodec 56. 1.100 / 56. 1.100
libavformat 56. 4.100 / 56. 4.100
libavdevice 56. 0.100 / 56. 0.100
libavfilter 5. 1.100 / 5. 1.100
libswscale 3. 0.100 / 3. 0.100
libswresample 1. 1.100 / 1. 1.100
libpostproc 53. 0.100 / 53. 0.100
Input #0, mp3, from 'SILENCE.mp3':
Metadata:
title : Snowblind (Featuring Tasha Baxter)
artist : Au5
album : Snowblind (Featuring Tasha Baxter)
genre : Electronica
performer : Au5
track : 1/1
date : 2014
album_artist : Au5,Tasha Baxter
major_brand : mp42
minor_version : 0
compatible_brands: isommp42
encoder : Lavf55.42.100
Duration: 00:05:50.80, start: 0.025057, bitrate: 192 kb/s
Stream #0:0: Audio: mp3, 44100 Hz, stereo, s16p, 192 kb/s
Output #0, mp3, to 'SILENCE_OUT.mp3':
Metadata:
TIT2 : Snowblind (Featuring Tasha Baxter)
TPE1 : Au5
TALB : Snowblind (Featuring Tasha Baxter)
TCON : Electronica
TPE3 : Au5
TRCK : 1/1
TDRL : 2014
TPE2 : Au5,Tasha Baxter
major_brand : mp42
minor_version : 0
compatible_brands: isommp42
TSSE : Lavf56.4.100
Stream #0:0: Audio: mp3 (libmp3lame), 44100 Hz, stereo, s16p, 192 kb/s
Metadata:
encoder : Lavc56.1.100 libmp3lame
Stream mapping:
Stream #0:0 -> #0:0 (mp3 (native) -> mp3 (libmp3lame))
Press [q] to stop, [?] for help
[silencedetect @ 0000000004398f40] silence_start: -0.00628118
[silencedetect @ 0000000004398f40] silence_end: 3.21413 | silence_duration: 3.22
041
[silencedetect @ 0000000004398f40] silence_start: 343.844
[libmp3lame @ 00000000043b2940] Trying to remove 1152 samples, but the queue is
empty
size= 8223kB time=00:05:50.79 bitrate= 192.0kbits/s
video:0kB audio:8222kB subtitle:0kB other streams:0kB global headers:0kB muxing
overhead: 0.011485%

然而,生成的音频文件仍然具有原始长度,没有删除任何静音。
请参阅以下图片:
http://i.imgur.com/nVxe5lX.png

任何帮助表示赞赏!

编辑:
好吧,静音检测只是检测静音。不删除它。我将尝试为此发布解决方案。

最佳答案

使用 silenceremove筛选。 这只会从音轨中删除静音-它将使视频保持未编辑状态,即,事情将不同步

它的论点有点神秘。

一个例子

ffmpeg -i input.mp3 -af silenceremove=1:0:-50dB output.mp3

这消除了沉默
  • 开头(由第一个参数 1 表示)
  • 最小长度为零(由第二个参数 0 指示)
  • 静音被归类为低于 -50 分贝的任何声音(由 -50dB 表示)。

  • 文档:
    FFMPEG silence remove filter

    任何想要找到正确的值来对静音进行分类的人都可能希望将他们的输入音量标准化为 0dB。首先,要在 ffmpeg 中执行此操作,请参阅 this answer .

    编辑

    正如@mems 所指出的,检测您的ffmpeg 版本是否运行了过滤器
    ffmpeg -hide_banner -filters | grep silenceremove
    如果你有过滤器,它会输出类似
    silenceremove A->A Remove silence

    关于audio - 使用 FFMPEG 和静音检测来消除音频静音,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25697596/

    24 4 0
    Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
    广告合作:1813099741@qq.com 6ren.com