Praat脚本-036 | Praat脚本批量为音频添加首尾静音段

有一个小的应用是有一批音频信号,想批量的通过脚本为这些音频信号在首、尾都增加一小段静音段。这里就通过Praat生成一小段静音段的音频信号,再分别拼接到原来音频信号的首、尾,从而保存为新的音频信号。

首先看一下Praat里是如何生成一段静音信号的。在Praat里可以通过公式生成一些基础频率的信号,我们来查看一下Praat帮助信息。

Creating a Sound from a formula

Choose Create Sound from formula… and type the following into the Formula field:

1/2 * sin (2 * pi * 377 * x)
When you click OK, a new Sound object will appear in the list. After you click View & Edit and zoom in a couple of times, you will see that the sound is a sine wave with a frequency of 377 hertz (cycles per second). This worked because the x in the formula represents the time, i.e. the formula was applied to every sample separately, with a different value of x for each sample.

通过这个命令可以创建一段周期为377Hz的正弦波信号,这里的x代表的就是时间轴的变化。这个公式可以根据不同的采样率来生成相应的采样点。

为了生成静音信号,我们只需要设置为0即可。

0 * x

提取数据

这个脚本在git目录里的第36个脚本36-add_silence_to_audio/add_silence_to_sound.praat

Praat运行脚本,Praat->Open Script->add_silence_to_sound.praat

  • 第一个输入:就是你的WAV所在的输入目录,这里是input_wav/
  • 第二个输入:就是你需要在首、尾想增加的静音段时长,这里是都设置为0.025
  • 第三个输入:就是与输入的音频匹配的采样率,这里样例用的是48K采样率,所以这里设置为48000
  • 第四个输出:是你需要设置的输出目录,这里是output_wav/
    在这里插入图片描述

最终运行之后可以得到增加了静音段的音频。我们查看一下。
在这里插入图片描述
由于我们前、后各增加了0.025,相当于增加了0.05秒的静音段,在总时长上也是体现出来的。放大音频信号,看到首尾,增加了一段0值的静音段。

首、尾不同时长,如何设置?

因为Praat在拼接音频时,只能按照读入的顺序,从下到下拼接,所以为了拼接得到最后的音频,我们只能先创建一个首静音段before, 再读入原始音频,再生成尾静音段after,这样将三个全部选中,进行拼接。所以如果想让首、尾静音段不同的时长,可以将以下一段代码修改:

Create Sound from formula: "before", 1, 0, addSilenceDuration, samplingFrequency, "0 * x"

for ifile from 1 to numberFiles
	select Strings fileList
	fileName$ = Get string: ifile
	Read from file: inputDirectory$ + fileName$
	objectName$ = selected$("Sound", 1)
	Create Sound from formula: "after", 1, 0, addSilenceDuration, samplingFrequency, "0 * x"

修改为:

Create Sound from formula: "before", 1, 0, 0.05, samplingFrequency, "0 * x"

for ifile from 1 to numberFiles
	select Strings fileList
	fileName$ = Get string: ifile
	Read from file: inputDirectory$ + fileName$
	objectName$ = selected$("Sound", 1)
	Create Sound from formula: "after", 1, 0, 0.08, samplingFrequency, "0 * x"

请仔细看,第二段代码没有使用默认的同样的拼接时长,而是变成了首静音段拼接0.05秒的时长,尾静音段拼接0.08秒的时长;大家可根据自己的需要更改。

采样率

如果查看自己的原始音频采样率呢?需要在Praat里点击Info按钮。通常有480004410022050160008000。需要改变自己音频采样率的,请参考这篇文章Praat脚本-001 | 音频文件重新采样
在这里插入图片描述

补充说明

本站之前发布的大多数脚本都是采用的相对路径,即input_wav/这样,没有将哪个盘,哪个目录都列出来,这是因为这些目录本身就在和脚本同样的目录下,这是完全没有问题的,经常在咨询群里看到有一些同学自己并不熟悉路径,总是弄错路径,其实我提到过多次了,你就不要动我现在设置的路径,将你的数据放在我的目录里运行就可以了。

获取脚本

https://github.com/feelins/Praat_Scripts

本站所有Praat脚本都可以在上述github的项目目录里找到,如果日常对代码、脚本操作比较熟练的可通过下载、安装、配置github for windows在自己的电脑上通过git clone将代码下载到本机,这样的好处是可以跟主站及时更新代码。
不想费如此脑筋,可以通过点击如下图Code位置所示,下载整站的代码,可直接使用。
在这里插入图片描述

关注

公众号:极地语音工作室, QQ讨论群720939827
在这里插入图片描述

版权说明

1、版权归本博客作者所有;

2、未经本站或者作者允许, 不得任意转载本文内容,否则将视为侵权;

3、转载或者引用本文内容请注明来源及原作者;

4、对于不遵守此声明或者其他违法使用本站内容者,本人依法保留追究权等。

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

极地语音工作室

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值