2

我在 Windows 命令行中编写了一个批处理程序来获取立体声 wav 文件并使用 sox v.14.4.0 音频程序将左右声道拆分为单独的 FLAC 文件。像这样。。

for /r %%n in (*.wav) do (
 C:\sox\sox.exe %%n -c 1 %%n.left.flac remix 1
 C:\sox\sox.exe %%n -c 2 %%n.right.flac remix 2)

但是,这比我想要的要长一点。我对此进行了更多研究,看来我可以使用 SOX_OPTS 和 --multi-thread 选项以及 --buffer 以同时执行两个 sox 操作。

Sox 文档说明了这一点:

SOX_OPTS 环境变量可用于为 SoX 的全局选项提供替代默认值。例如:

SOX_OPTS="−−buffer 20000 −−play−rate−arg −hs −−temp /mnt/temp"

请注意,设置环境变量的方式因系统而异。以下是一些示例: MS-DOS/MS-Windows:

set SOX_OPTS=−V −−no-clobber −−buffer BYTES, −−input−buffer BYTES

设置用于处理音频的缓冲区的大小(默认为 8192)。
−−buffer适用于输入、效果和输出处理;
−−input−buffer 仅适用于输入处理(如果两者都给定,它将覆盖−−buffer)。
请注意,−−buffer 的较大值将导致 SoX 响应终止或跳过当前输入文件的请求变得缓慢。

两个问题。

  1. 是否可以使用 --multi-thread 如上所述或其他方式同时将 1 个输入文件拆分为 2 个输出文件?
  2. 如果是这样,怎么做?(注意:我无法找出正确的语法来从上面的文档中获取 SOX_OPTS 以自行处理,不要介意在批处理文件中)

另外:我发现了一些与此类似的其他 stackoverflow 问题,但总是使用 java、php、linux 等。不幸的是,我对这些程序一无所知。请同情我的编程无知。

4

1 回答 1

3

没有比我更喜欢你的 SoX 更熟悉的想法......

但是,我会试试这个:

作为测试,使用单个 .wav 文件

for /r %%n in (justone.wav) do (
 START "Left" C:\sox\sox.exe %%n -c 1 %%n.left.flac remix 1
 START "Right" C:\sox\sox.exe %%n -c 2 %%n.right.flac remix 2)

也许它会在多处理器机器上同时运行两个实例。(窗口标题为“左”或“右”)

现在-如果可行,请尝试

@ECHO OFF
SETLOCAL
for /r %%n in (*.wav) do CALL :runsox "%%n"
GOTO :eof

:runsox
CALL :wait
START "%~1.left" C:\sox\sox.exe %~1 -c 1 %~1.left.flac remix 1
CALL :wait
START "%~1.right" C:\sox\sox.exe %~1 -c 2 %~1.right.flac remix 2
GOTO :eof

:wait
FOR /f %%c IN ('tasklist^|find /i /c "sox.exe"') DO SET running=%%c
IF %running% GEQ 6 timeout /t 5 >nul&GOTO wait
GOTO :eof

这将执行:runsox每个.wav遇到的过程,传递 .wav 名称。

runsox过程将调用该wait过程 - 我会谈到。完成WAIT后,它将放在左边的 sox 上,然后再次等待并放在右边,然后返回下一个文件名,直到一切都完成。名称中的%~1表示“给这个例程的第一个参数,减去任何封闭的引号”——这就是 CALL 提供的文件名 (%%n)。

wait过程通过SOX.EXE从过滤器传递任务列表来找出正在运行的实例数量,以查找字符串意味着不考虑大小写,并意味着输出计数。tasklistfindsox.exe /i/c

Running因此获取SOX正在进行的实例的计数。如果大于或等于 6(任意数字 - 选择适合自己的值。最好留一或两个处理器用于其他任务,因此 6 id 适合 8 处理器机器)然后执行 5 秒的超时5 秒后再次检查任务列表。当实例少于 6 个时,wait程序退出并开始下一个任务。

所以 - 该WAIT过程一直等到少于 6 个 SOX 实例。

更改 6 以适合您的机器和 5 您的审美。

编辑:删除旧的右括号

于 2013-04-12T21:56:38.890 回答