TranslateProject/translated/tech/20210202 Convert audio files with this versatile Linux command.md
FYJNEVERFOLLOWS d17f82a7d2 move
2022-11-10 20:39:30 +08:00

10 KiB
Raw Blame History

使用这个多功能的 Linux 命令转换音频文件

SoX Sound Exchange 甚至可以为您的音频文件添加特效。 HiFi vintage stereo

我与媒体打交道,当你与任何一种媒体打交道时,你很快就会知道标准化是一种有价值的工具。就像你不会试图在不转换其中一个或另一个的情况下将分数加到小数中一样,我已经了解到组合不同格式的媒体并不是理想的。为了方便用户,大多数爱好者级应用程序使转换过程不可见。然而,对于那些需要控制媒体细节的用户的灵活软件,会通常让你自己提前将媒体转换为所需的格式。我有一些最喜欢的音频转换工具,其中之一就是号称“声音的瑞士军刀” —— SoX

安装

在 Linux 或 BSD 上,可以从软件存储库或端口树中安装 sox 命令(和一些有用的符号链接)。

你也可以从 Sourceforge.net 上安装 SoX。它不经常发布但它的代码库往往是稳定的所以如果你想要最新的功能如 Opus 支持),构建它是容易和安全的。

SoX 主要提供了 SoX 命令,但是安装 SoX 也创建了一些有用的符号链接:playrecsoxi

使用 SoX 获取有关文件的信息

SoX 读取和重写音频数据。它是否存储重写的音频数据取决于你。在有些情况下,你不需要存储转换后的数据,例如,当你将输出直接发送到扬声器进行回放时。然而,在进行任何转换之前,最好首先确定要处理的是什么。

使用 soxi 命令也可以收集音频文件信息。soxi 会符号链接到 soxi--info

$ soxi countdown.mp3
Input File输入文件    : '/home/tux/countdown.mp3'
Channels通道数       : 1
Sample Rate采样率    : 44100
Precision数据精度      : 16-bit16 比特)
Duration时长       : 00:00:11.21 = 494185 samples...11.21 秒 = 494185 采样点)
File Size文件大小      : 179k
Bit Rate比特率       : 128k
Sample Encoding编码格式: MPEG audio (layer I, II or III)

这个输出可以让你很好地了解音频文件的编码方式、文件长度、文件大小、采样率和通道数。其中一些你可能认为你已经知道了,但当客户把媒体带到我面前时,我从不相信这些假设。使用 soxi 验证媒体属性。

转换文件

在本例中,游戏节目的音频以 MP3 文件的形式展示倒计时。虽然几乎所有的编辑应用程序都接受压缩音频,但它们都没有真正编辑压缩数据。转换是在某个地方发生的,可能是一个秘密的后台任务,也可能是让你保存一份副本的提示。我通常喜欢自己提前完成转换。这样,我可以控制使用的格式。我可以在一夜之间批量制作大量的媒体,而不是浪费宝贵的制作时间,等待编辑应用程序按需浏览它们。

sox 命令用于转换音频文件。在 sox 流程中有几个阶段:

  • 输入
  • 合并
  • 特效
  • 输出

在命令语法中,特效步骤令人困惑地写到最后一步。这意味着 sox 流程是这样组成的:

输入 → 合并 → 输出 → 特效

编码

最简单的转换命令只涉及一个输入文件和一个输出文件。下面是转换 MP3 文件为无损 FLAC 文件的命令:

$ sox countdown.mp3 output.flac
$ soxi output.flac

Input File输入文件     : 'output.flac'
Channels通道数       : 1
Sample Rate采样率    : 44100
Precision数据精度      : 16-bit16 比特)
Duration时长       : 00:00:11.18 = 493056 samples...11.18 秒 = 493056 采样点)
File Size文件大小      : 545k
Bit Rate比特率       : 390k
Sample Encoding编码格式: 16-bit FLAC
Comment注释        : 'Comment=Processed by SoX'

特效

特效可以在命令末尾指定。它可以在将数据发送到最终目的地之前更改音频。例如,有时声音太大会在转换过程中造成问题:

$ sox bad.wav bad.ogg
sox WARN sox: `bad.ogg' output clipped 126 samples; decrease volume?

应用增益 (gain) 效果通常可以解决此问题:

`$ sox bad.wav bad.ogg gain -1`

淡入淡出

另一个常用的效果是淡入淡出。此效果允许你定义淡入或淡出的形状,以及你希望淡入淡出效果持续的时间。

下面是一个使用倒抛物线的 6 秒淡入示例:

`$ sox intro.ogg intro.flac fade p 6`

这将对音频的头部应用 3 秒的淡入,并从 8 秒标记开始淡出(介绍音乐只有 11 秒因此在这种情况下淡出也是3秒

`$ sox intro.ogg intro.flac fade p 3 8`

sox 手册页中列出了不同类型的淡入淡出(正弦、线性、倒抛物线等)以及**淡入淡出提供的选项。

特效语法

每个特效插件都有自己的语法,因此请参阅手册页了解如何调用每个特效插件的详细信息。要做到这一点,你需要一个图形声波编辑器或数字音频工作站,例如 LMMSRosegarden。但是,如果你只想应用一次特效,可以在同一命令中将它们一起列出。

此命令应用 -1 的增益效果、1.35 的速度拉伸淡入淡出

$ sox intro.ogg output.flac gain -1 stretch 1.35 fade p 0 6
$ soxi output.flac

Input File输入文件     : 'output.flac'
Channels通道数       : 1
Sample Rate采样率    : 44100
Precision数据精度      : 16-bit16 比特)
Duration时长        : 00:00:15.10 = 665808 samples...15.10 秒 = 665808 采样点)
File Size文件大小      : 712k
Bit Rate比特率       : 377k
Sample Encoding编码格式: 16-bit FLAC
Comment注释        : 'Comment=Processed by SoX'

组合音频

SoX 还可以通过连接或混合音频文件来组合音频文件。

要连接(或拼接)文件合并为一个文件,请在命令中提供多个输入文件:

`$ sox countdown.mp3 intro.ogg output.flac`

在本例中,output.flac 现在包含 倒计时 音频,紧接着是简介 音乐。

但是,如果你希望两首曲目同时播放,可以使用 --combine mix 选项:

`$ sox --combine mix countdown.mp3 intro.ogg output.flac`

然而想象一下这两个输入文件的不同之处不仅仅在于它们的编解码器。声音用单声道一个声道录制并不少见但音乐要用立体声至少两个声道来录制。SoX 不会给出默认的解决方案,因此你必须首先自己标准化这两个文件的格式。

更改音频文件

选项只与后面列出的文件名相关。例如,此命令中的 --channels 选项将仅仅应用于 input.wav,而不被应用于 example.oggoutput.flac

`$ sox --channels 2 input.wav example.ogg output.flac`

这意味着在 SoX 中,选项的位置非常重要。如果你在命令开始时指定一个选项,那么实际上只会覆盖 SoX 自己从输入文件中收集的内容。然而,在输出文件名 前的选项决定了 SoX 如何写入音频数据。

要解决以前的不兼容通道问题,你可以首先标准化输入,然后混合:

$ sox countdown.mp3 --channels 2 countdown-stereo.flac gain -1
$ soxi countdown-stereo.flac

Input File输入文件     : 'countdown-stereo.flac'
Channels通道数       : 2
Sample Rate采样率    : 44100
Precision数据精度      : 16-bit16 比特)
Duration时长       : 00:00:11.18 = 493056 samples...11.18 秒 = 493056 采样点)
File Size文件大小      : 545k
Bit Rate比特率       : 390k
Sample Encoding编码格式: 16-bit FLAC
Comment注释        : 'Comment=Processed by SoX'

$ sox --combine mix \
countdown-stereo.flac \
intro.ogg \
output.flac

SoX 绝对需要多个命令来执行复杂的操作,因此根据需要创建几个临时和中间文件是正常的。

多通道音频

当然,并非所有音频都被限制在一个或两个声道。如果您想将多个音频通道组合成一个文件,可以使用 SoX 和 --combine merge 选项:

$ sox --combine merge countdown.mp3 intro.ogg output.flac
$ soxi output.flac

Input File     : 'output.flac'
Channels       : 3
[...]

简单的音频操作

在没有视觉界面的情况下操作音频似乎很奇怪而且对于某些任务来说SoX 绝对不是最好的工具。然而对于许多任务SoX 提供了一个简单而轻量级的工具包。SoX 是一个具有强大潜力的简单命令。有了它,你可以转换音频,操纵通道和波形,甚至生成自己的声音。本文仅简要概述了其功能,因此请阅读其手册页或在线文档,然后看看你能创造什么。


via: https://opensource.com/article/20/2/linux-sox

作者:Klaatu 选题:lujun9972 译者:FYJNEVERFOLLOWS 校对:校对者ID

本文由 LCTT 原创编译,Linux中国 荣誉推出