0

我正在努力将一些以g729 8000Hz 17448bits编码的立体声 WAV 音频文件解码为任何可播放格式。我将这些音频传递到我用 Python 制作的语音识别代码中,但它们不适用于该代码。当我尝试使用 VLC、Groove 或 Windows Media Player 播放时,仍然无法正常工作。

我尝试使用像这样的命令行 ffmpeg 命令来转换它们:

ffmpeg -f g729 -i input.WAV -ac 2 output.WAV

结果实际上是可以播放的,但只能听到NOISE而不是预期的声音。

由于 ffmpeg 确实支持解码 g729 文件,我想在使用 ffmpeg 命令时可能会丢失一些东西......

这些文件没有损坏,事实上,我的同事经常使用 SaaS 播放它们。

提前感谢您的帮助!

编辑:

运行上面突出显示的命令时,ffmpeg 打印的日志如下:

(base) C:\Users\soare\Desktop>ffmpeg -f g729 -i f.WAV -ac 2 output.WAV
ffmpeg version 4.2.2 Copyright (c) 2000-2019 the FFmpeg developers
  built with gcc 9.2.1 (GCC) 20200122
  configuration: --disable-static --enable-shared --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-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-libvorbis --enable-libvo-amrwbenc --enable-libmysofa --enable-libspeex --enable-libxvid --enable-libaom --enable-libmfx --enable-amf --enable-ffnvcodec --enable-cuvid --enable-d3d11va --enable-nvenc --enable-nvdec --enable-dxva2 --enable-avisynth --enable-libopenmpt
  libavutil      56. 31.100 / 56. 31.100
  libavcodec     58. 54.100 / 58. 54.100
  libavformat    58. 29.100 / 58. 29.100
  libavdevice    58.  8.100 / 58.  8.100
  libavfilter     7. 57.100 /  7. 57.100
  libswscale      5.  5.100 /  5.  5.100
  libswresample   3.  5.100 /  3.  5.100
  libpostproc    55.  5.100 / 55.  5.100
[g729 @ 00000289cbca05c0] Estimating duration from bitrate, this may be inaccurate
Guessed Channel Layout for Input Stream #0.0 : mono
Input #0, g729, from 'f.WAV':
  Duration: 00:02:34.06, start: 0.000000, bitrate: 8 kb/s
    Stream #0:0: Audio: g729, 8000 Hz, mono, s16p
File 'output.WAV' already exists. Overwrite ? [y/N] y
Stream mapping:
  Stream #0:0 -> #0:0 (g729 (native) -> pcm_s16le (native))
Press [q] to stop, [?] for help
Output #0, wav, to 'output.WAV':
  Metadata:
    ISFT            : Lavf58.29.100
    Stream #0:0: Audio: pcm_s16le ([1][0][0][0] / 0x0001), 8000 Hz, stereo, s16, 256 kb/s
    Metadata:
      encoder         : Lavc58.54.100 pcm_s16le
[g729 @ 00000289cbcac140] pitch_delay_int 144 is too large
f.WAV: corrupt input packet in stream 0
size=    4814kB time=00:00:01.93 bitrate=20375.8kbits/s speed=7.22x
video:0kB audio:4814kB subtitle:0kB other streams:0kB global headers:0kB muxing overhead: 0.001582%
4

0 回答 0