linux读入文件分行操作,linux shell脚本如何将文本内容按空格分行、如何使用timit原始corpus制作wav的scp文件...

本文主要是介绍linux读入文件分行操作,linux shell脚本如何将文本内容按空格分行、如何使用timit原始corpus制作wav的scp文件...,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在kaldi-trunk提供的例子voxforge中有一个online-demo

直接使用就可以完成样例的在线解码并得到一个不错的结果,但是数据量很小

前段时间试了一下用另一个corpus来做同样的事情,但是效果很差

今天想用timit corpus来试一试

在修改run.sh脚本过程中遇到了很多问题,主要是对shell脚本操作不熟悉

其中有一个步骤是需要制作corpus中的wav的scp文件

timit的原始语料库中的文件层级是这样的:

第一级:

0818b9ca8b590ca3270a3433284dd417.png

第二级:

0818b9ca8b590ca3270a3433284dd417.png

第三极:

0818b9ca8b590ca3270a3433284dd417.png

第四级:

0818b9ca8b590ca3270a3433284dd417.png

第五级:

0818b9ca8b590ca3270a3433284dd417.png

我这里只选择了TEST作为decoding的对象,所以只需要关注TEST目录下的结构,下面是scp文件制作实现过程:

step1:

> $decode_dir/input.scp

这一步是run.sh文件中原本就有的,但也很重要,即创建一个scp文件,同时还起到的一个作用是,如果之前生成过一个不需要的scp文件可以将其覆盖掉。

step2:

find $audio -not \( -iname 'SA*' \) -name '*.WAV' -print | xargs echo "" > $decode_dir/input.scp.temp

这一步达到的效果是将所有WAV文件中前缀不为SA的地址提取出来并存放在input.scp.temp这个中间文件中

这一步执行完之后得到的input.scp.temp文件是这个样子的:

0818b9ca8b590ca3270a3433284dd417.png

也就是,我生成的文件中有三行,每一行都包括了很多个WAV文件,还不知道为什么会这样,这自然不是我希望得到的最后结果,所以需要进一步处理。

step3:

OLD_IFS="$IFS"

IFS=" "

cat $decode_dir/input.scp.temp | while read line

do

arr=($line)

IFS="$OLD_IFS"

for s in ${arr[@]}

do

echo ${s##*/} `pwd`"/$s" >> $decode_dir/input.scp

done

done

首先要实现的是将文本一行一行读入之后再用空格作为分隔符,将一行中的多个元素形成一个数组arr,详情请参考:http://my.oschina.net/5lei/blog/189559

然后是要制作成scp的格式,即文本的每一行为: wav名   wav所在的绝对路径

所以就有了echo ${s##*/} `pwd`"/$s" >> $decode_dir/input.scp这句话

${s##*/}的意思是取字符串s最后出现的 “/”这个字符,将这个字符及其左边所有的字符都删除掉,只取其右边剩下的部分,因此就得到了wav文件名

`pwd`"/$s"自然对应的就是wav文件的绝对路径了,`pwd`表示当前目录的绝对路径,后面再加上"/$s"也就构成了完整的文件路径。

最后终于得到了想要的scp文件:

0818b9ca8b590ca3270a3433284dd417.png

就只是以上这一点东西就花了我一天的时间,主要还是对linux指令的使用太不熟悉,

如果熟悉linux指令的话这应该是很简单的事情,好好学习,希望越来越好。

这篇关于linux读入文件分行操作,linux shell脚本如何将文本内容按空格分行、如何使用timit原始corpus制作wav的scp文件...的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/206147

相关文章

使用Dify访问mysql数据库详细代码示例

《使用Dify访问mysql数据库详细代码示例》:本文主要介绍使用Dify访问mysql数据库的相关资料,并详细讲解了如何在本地搭建数据库访问服务,使用ngrok暴露到公网,并创建知识库、数据库访... 1、在本地搭建数据库访问的服务,并使用ngrok暴露到公网。#sql_tools.pyfrom

使用mvn deploy命令上传jar包的实现

《使用mvndeploy命令上传jar包的实现》本文介绍了使用mvndeploy:deploy-file命令将本地仓库中的JAR包重新发布到Maven私服,文中通过示例代码介绍的非常详细,对大家的学... 目录一、背景二、环境三、配置nexus上传账号四、执行deploy命令上传包1. 首先需要把本地仓中要

Spring Cloud之注册中心Nacos的使用详解

《SpringCloud之注册中心Nacos的使用详解》本文介绍SpringCloudAlibaba中的Nacos组件,对比了Nacos与Eureka的区别,展示了如何在项目中引入SpringClo... 目录Naacos服务注册/服务发现引⼊Spring Cloud Alibaba依赖引入Naco编程s依

Java springBoot初步使用websocket的代码示例

《JavaspringBoot初步使用websocket的代码示例》:本文主要介绍JavaspringBoot初步使用websocket的相关资料,WebSocket是一种实现实时双向通信的协... 目录一、什么是websocket二、依赖坐标地址1.springBoot父级依赖2.springBoot依赖

Linux下修改hostname的三种实现方式

《Linux下修改hostname的三种实现方式》:本文主要介绍Linux下修改hostname的三种实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录linux下修改ho编程stname三种方式方法1:修改配置文件方法2:hFvEWEostnamectl命

Java使用Mail构建邮件功能的完整指南

《Java使用Mail构建邮件功能的完整指南》JavaMailAPI是一个功能强大的工具,它可以帮助开发者轻松实现邮件的发送与接收功能,本文将介绍如何使用JavaMail发送和接收邮件,希望对大家有所... 目录1、简述2、主要特点3、发送样例3.1 发送纯文本邮件3.2 发送 html 邮件3.3 发送带

Linux虚拟机不显示IP地址的解决方法(亲测有效)

《Linux虚拟机不显示IP地址的解决方法(亲测有效)》本文主要介绍了通过VMware新装的Linux系统没有IP地址的解决方法,主要步骤包括:关闭虚拟机、打开VM虚拟网络编辑器、还原VMnet8或修... 目录前言步骤0.问题情况1.关闭虚拟机2.China编程打开VM虚拟网络编辑器3.1 方法一:点击还原VM

使用DeepSeek搭建个人知识库(在笔记本电脑上)

《使用DeepSeek搭建个人知识库(在笔记本电脑上)》本文介绍了如何在笔记本电脑上使用DeepSeek和开源工具搭建个人知识库,通过安装DeepSeek和RAGFlow,并使用CherryStudi... 目录部署环境软件清单安装DeepSeek安装Cherry Studio安装RAGFlow设置知识库总

Linux搭建Mysql主从同步的教程

《Linux搭建Mysql主从同步的教程》:本文主要介绍Linux搭建Mysql主从同步的教程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录linux搭建mysql主从同步1.启动mysql服务2.修改Mysql主库配置文件/etc/my.cnf3.重启主库my

Python FastAPI入门安装使用

《PythonFastAPI入门安装使用》FastAPI是一个现代、快速的PythonWeb框架,用于构建API,它基于Python3.6+的类型提示特性,使得代码更加简洁且易于绶护,这篇文章主要介... 目录第一节:FastAPI入门一、FastAPI框架介绍什么是ASGI服务(WSGI)二、FastAP