小学的语文的听写词语很多时候耗费了家长的很多精力,孩子写得慢,家长说不清楚等等的状况,突然想到了语音合成应该能补上这个痛点,于是找了一下python关于实现语音合成的资料,发现pyttsx3库不错,简单写了个程序解决了问题,能实现顺序听写,全部随机听写,每个词语重复次数可控,间隔时间可调等功能。
#tts.py
import pyttsx3
from time import sleep
import random
engine = pyttsx3.init() # 初始化语音引擎
engine.setProperty('rate', 150) # 设置语速
engine.setProperty('volume', 0.8) # 设置音量
voices = engine.getProperty('voices')
engine.setProperty('voice', voices[0].id) # 设置第一个语音合成器
intervaltime=8#一次性暂停时间
chartime=3#按字符数的每字符暂停时间
intervaltype=1#暂停时间计算方式,0-一次性,1-按字符数累加
repeattimes=1#每个词语重复朗读次数
intervalrepeat=1#每个词语重复朗读时的停顿时间
order=-1#词语朗读顺序,0-随机,1-正序,-1-倒序
words=[]
# 打开文件
with open('words.txt', 'r', encoding='utf-8', errors='ignore') as file:
# 按行读取
for line in file:
# 处理每一行
word=line.strip()
words.append(word)
numbers = list(range(1, len(words)))
if order==1:
numbers = list(reversed(numbers))
if order==0:
random.shuffle(numbers)
for x in range(len(words)-1):
selected_number = numbers[-1]
#print(selected_numbers)
#print(numbers)
numbers = numbers[:-1]
word=words[selected_number]
for i in range(repeattimes):
print(word)
engine.say(word)
engine.runAndWait()
if i < repeattimes - 1:
print('停顿%s秒' % intervalrepeat)
sleep(intervalrepeat)
if intervaltype == 0:
print('暂停%s秒' % intervaltime)
sleep(intervaltime)
else:
length = len(word)
pausetime = chartime * length
print('暂停%s秒' % pausetime)
sleep(pausetime)
word='完成'
print(word)
engine.say(word)
engine.runAndWait()
engine.stop()
需要听写的词语存放于同目录的words.txt文件,每行一个需要听写的词语。order变量控制词语听写的顺序,0是随机且抽取全部,用一个shuffle了的数组,每次读数组最后一个值并删除该元素,1是顺序,-1是倒序。