gpt4 book ai didi

audio - ffmpeg:刷新每个 block 的输出文件

转载 作者:行者123 更新时间:2023-12-02 08:08:13 25 4
gpt4 key购买 nike

我正在使用 ffmpeg 实时生成 10 秒的正弦音。不幸的是,ffmpeg 似乎很少刷新输出文件,每隔几秒一次。我希望它每 2048 字节刷新一次(=2 字节样本宽度*1024 样本,我的自定义 block 大小)。

以下脚本的输出:

import os
import time
import subprocess

cmd = 'ffmpeg -y -re -f lavfi -i "sine=frequency=440:duration=10" -blocksize 2048 test.wav'

subprocess.Popen(cmd, shell=True)

time.sleep(0.1)
while True:
print(os.path.getsize("test.wav"))
time.sleep(0.1)

看起来像:

[...]
78
78
78
262222
262222
262222
[...]

#ffmpeg IRC 上的用户建议使用

ffmpeg -re -f lavfi -i "sine=frequency=1000:duration=10" -f wav pipe: > test.wav

有效。但这可以仅使用 ffmpeg 来实现吗?

最佳答案

为了输出到文件,ffmpeg 在写入之前等待填充 256 KiB 的缓冲区。

您可以使用flush_packets禁用该行为。

ffmpeg -y -re -f lavfi -i "sine=f=440:d=10" -blocksize 2048 -flush_packets 1 test.wav

关于audio - ffmpeg:刷新每个 block 的输出文件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50574086/

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