ICode9

精准搜索请尝试: 精确搜索
首页 > 编程语言> 文章详细

python – 如何通过文本到语音(pyTTS或SAPI5)延长单词之间的暂停

2019-06-26 21:43:11  阅读:414  来源: 互联网

标签:python accessibility text-to-speech sapi


使用SAPI5使用文本到语音时,是否可以扩大口语之间的差距?

问题是,尤其是有些声音,这些词几乎相互联系,这使得演讲更难以理解.

我正在使用python和pyTTS模块(在Windows上,因为它使用的是SAPI)

我试图挂钩OnWord事件并添加time.sleep()或tts.Pause(),但显然即使所有事件都被捕获,它们只在语音文本的末尾处理,不管我是不是使用sync或async标志.

在这个非工作示例中,只有在说出句子后才执行sleep()方法:

tts = pyTTS.Create()
def f(x):
    tts.Pause()
    sleep(0.5)
    tts.Resume()

tts.OnWord = f
tts.Speak(text)

编辑: – 接受的解决方案

我的实际答案要么是

>用自己的“说话”命令说出每个单词,(由@Lennart Regebro建议),或者
>用逗号替换每个空格(如@Dawson所述),例如:

text = text.replace(“”,“,”)

这设置了一个合理的停顿.我之前没有提到Pause方法,因为’我对接受的解决方案感到满意.

解决方法:

你在谈论语音速率,对吧?
http://msdn.microsoft.com/en-us/library/ms990078.aspx

暂停()我相信,在正常的语音模式中,它的作用很像逗号…除了你确定长度(自然与否).

标签:python,accessibility,text-to-speech,sapi
来源: https://codeday.me/bug/20190626/1298241.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有