gpt4 book ai didi

ffmpeg - 是否可以对具有确切长度(到毫秒)的音频流进行编码?

转载 作者:行者123 更新时间:2023-12-04 22:53:09 25 4
gpt4 key购买 nike

我希望创建一个长度为 的输出文件正是 mp3、aac 或 vorbis 编解码器中的 30 秒。我已经通过以下命令使用了 avconv(也尝试了 ffmpeg):

avconv  -i input_file_here -c:a aac -b:a 320k -t 30 out.mp4

这会产生输出,说明它已经编码了 30 秒,但随后:
$ avprobe out.mp4
avprobe version v13_dev0-1648-gc4642788e, Copyright (c) 2007-2018 the Libav developers
built on Apr 24 2019 15:49:35 with gcc 7 (Ubuntu 7.3.0-27ubuntu1~18.04)
Input #0, mov,mp4,m4a,3gp,3g2,mj2, from 'out.mp4':
Metadata:
major_brand : isom
minor_version : 512
compatible_brands: isomiso2mp41
encoder : Lavf57.83.100
Duration: 00:00:30.02, start: 0.023220, bitrate: 323 kb/s
Stream #0:0(und): Audio: aac (LC) [mp4a / 0x6134706D]
44100 Hz, stereo, fltp, 321 kb/s (default)
Metadata:
handler_name : SoundHandler
# avprobe output

当我在 mp3 中编码时,它正确显示它在编码过程中超过 30 秒。当我尝试使用 vorbis 时,它的运行时间略少于 30 秒。

是否可以使用任何工具(我更喜欢 avconv)来实现 30 秒到毫秒的长度。

最佳答案

在您的示例中,您使用的是 aac 音频 44100khz。 AAC 每帧使用 1024 个样本。
1024/44100 不能被 30 整除。所以,不,不可能。可能可以调整启动样本,但您需要了解启动样本的工作原理,并修改编码器。

Mp3 每帧使用 1152、572 或 384 个样本,具体取决于层。
可能有一个有效的组合。在这里查看更多https://hydrogenaud.io/index.php/topic,85125.0.html

我对vorbis一无所知,所以我不知道它是否可能。

关于ffmpeg - 是否可以对具有确切长度(到毫秒)的音频流进行编码?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55870922/

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