Bootstrap

[Python]使用pyttsx3将文字转语音

一、安装Pyttsx3

首先,你需要在你的Python环境中安装Pyttsx3库。可以通过pip命令进行安装:

pip install pyttsx3

二、基本使用方法

  1. 导入Pyttsx3库

    在你的Python脚本中,首先需要导入Pyttsx3库:

    import pyttsx3
    
  2. 初始化TTS引擎

    使用pyttsx3.init()方法初始化一个TTS引擎对象:

    engine = pyttsx3.init()
    
  3. 将文本转换为语音

    使用engine.say()方法将要转换的文本添加到TTS引擎的队列中等待转换。例如:

    engine.say("Hello, how are you today?")
    
  4. 运行并等待语音播放完成

    使用engine.runAndWait()方法启动TTS引擎,同步执行队列中的所有文本,并等待所有语音播放完成后才继续执行后续代码:

    engine.runAndWait()
    

三、高级功能

Pyttsx3库提供了许多高级功能,允许你控制转换后的语音的各种属性。

  1. 设置语速

    使用engine.setProperty('rate', new_rate)方法设置语速,其中new_rate是你想要的语速值(整数)。例如,设置语速为150(正常语速附近):

    engine.setProperty('rate', 150)
    
  2. 设置音量

    使用engine.setProperty('volume', volume)方法设置音量,其中volume是一个浮点数,范围从0.0(静音)到1.0(最大音量)。例如,设置音量为0.9:

    engine.setProperty('volume', 0.9)
    
  3. 设置语音

    在某些操作系统上,Pyttsx3支持多个语音。你可以使用engine.getProperty('voices')获取所有可用的语音列表,并通过设置voice属性来选择其中一个语音。例如,选择第一个语音:

    voices = engine.getProperty('voices')
    engine.setProperty('voice', voices[0].id)
    
  4. 保存语音到文件

    Pyttsx3还支持将转换后的语音保存到文件中,而不是直接播放出来。使用engine.save_to_file(text, filename)方法可以实现这一点。例如:

    text = "Hello, this is a saved audio."
    filename = "out
;