ffmpeg - 使用 ffmpeg 批量转换文件并找到 -exec 和并行

标签 ffmpeg find gnu-parallel

从另一个堆栈交换帖子中,我知道我可以批量转换原始文件名不变的媒体文件,并且只能使用以下方法更改文件扩展名

find ./ -name '*.mp4' -exec bash -c 'ffmpeg -i $0 -vn -acodec libmp3lame -ac 2 -ab 160k -ar 48000 ${0/mp4/mp3}' {} \;
由于现在大多数计算机都有多个内核,我该如何修改上面的命令,所以我可以使用 -exec 中的所有 4 个内核find 的一部分,因此我可以同时转换 4 个媒体文件?
我知道 GNU 并行可以做类似的事情,但我不知道如何将它们组合成一个命令。
提前致谢
哈夫

最佳答案

您可以将文件名以 null 结尾传递给 parallel像这样:

find . -name \*.mp4 -print0 | parallel -0 ...
您可以访问parallel中的参数通过 {}并且您可以使用 {.} 获取不带扩展名的文件名, 所以你要:
find . -name \*.mp4 -print0 | parallel -0 ffmpeg -i {} ... {.}.mp3
试试 parallel --dry-run首先看看它看起来是否正确。无论如何,它将默认使用所有内核。

关于ffmpeg - 使用 ffmpeg 批量转换文件并找到 -exec 和并行,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/65985342/

相关文章:

sed - sed 与 parallel --jobs 选项的正确用法是什么?

gnu-parallel - 如何引用 gnu parallel 中的每个参数?

android - 可执行二进制文件无法在 android marshmallow 上运行

ffmpeg 旋转图像以馈送 ffserver

javascript - 如何正确流式传输M4A文件?

file - Bash:按 MIME 类型查找文件的脚本

Python:按字符位置分割字符串

带有 Axis P1347 的 ffmpeg 返回 400 Bad Request,但 Axis 1357 有效

mongodb - 奇怪的 Mongoose 。我从 findOne 的文档中得到了废话。

bash - GNU 并行 stderr 与 --files 或合理的 --results 树