使用 Python 的 pyttsx3 库进行文本转语音

1. 什么是 pyttsx3?

1.1 pyttsx3 是一个 Python 库,它可以将文本转换为语音。与其他文本转语音库(如 gTTS)不同,pyttsx3 不依赖于网络服务,它使用本地的 TTS(Text-to-Speech)引擎,这使得它在离线状态下也能正常工作

1.2 pyttsx3 支持多平台(Windows、Linux 和 macOS),且可以对语音的音量、语速以及语音类型等进行控制

2. 安装 pyttsx3

要使用 pyttsx3,首先需要在你的 Python 环境中安装该库

你可以通过以下命令安装它:

复制代码
pip install pyttsx3

安装完成后,就可以开始使用它来生成语音了

3. 使用 pyttsx3 播放文本

下面是一个简单的示例,展示了如何使用 pyttsx3 库将文本转换为语音

示例代码:

复制代码
import pyttsx3

# 初始化 pyttsx3 引擎
engine = pyttsx3.init()

# 要转换的文本
text = "你好,欢迎使用 pyttsx3 库进行文本转语音转换。"

# 播放文本
engine.say(text)

# 等待语音播放完毕
engine.runAndWait()

在这段代码中,我们首先通过 pyttsx3.init() 初始化了语音引擎

然后通过 say() 方法将文本添加到语音队列中,最后通过 runAndWait() 方法让引擎开始播放并等待播放结束

4. 控制语音的参数

pyttsx3 库提供了几个可以控制语音效果的参数,包括音量、语速和语音类型

下面是如何调整这些参数的示例

控制音量

音量的取值范围是 0.0 到 1.0,默认值通常为 1.0

你可以通过 setProperty() 方法来设置音量

复制代码
engine.setProperty('volume', 0.9)  # 设置音量为 90%
控制语速

语速的默认值通常是 200(单位:字/分钟),你可以使用 setProperty() 方法来设置语速

复制代码
engine.setProperty('rate', 150)  # 设置语速为 150(单位:字/分钟)
控制语音类型

pyttsx3 允许你选择不同的语音引擎

你可以查看可用的语音列表并选择不同的语音类型(例如男声或女声)

复制代码
voices = engine.getProperty('voices')  # 获取可用的语音列表

# 打印出可用的语音类型
for voice in voices:
    print(f"ID: {voice.id}, Name: {voice.name}, Lang: {voice.languages}")

# 设置使用第一个语音(通常是男性语音)
engine.setProperty('voice', voices[0].id)

你可以通过循环输出所有的语音选项,选择你想要的语音

例如,你可以选择一个女性的语音或者不同的语言

5. 保存语音到文件

pyttsx3 默认是播放语音,而不是保存语音文件

如果你希望将生成的语音保存到一个文件中,pyttsx3 本身并没有直接支持输出到文件的功能,但你可以使用其他工具结合来实现,例如 pydub 或其他音频处理库

如果你有兴趣,可以查看下面的代码片段,它展示了如何使用 pydub 将 pyttsx3 的输出保存为 .mp3 文件:

复制代码
import pyttsx3
from pydub import AudioSegment
import os

# 使用 pyttsx3 生成语音并保存为 WAV 文件
engine = pyttsx3.init()
engine.save_to_file("你好,欢迎使用 pyttsx3 库进行文本转语音转换。", "output.wav")
engine.runAndWait()

# 使用 pydub 将 WAV 转换为 MP3
audio = AudioSegment.from_wav("output.wav")
audio.export("output.mp3", format="mp3")

# 删除临时的 WAV 文件
os.remove("output.wav")

6. 完整代码示例

下面是一个完整的示例代码,它演示了如何使用 pyttsx3 来控制音量、语速、语音类型,并将文本转换为语音:

复制代码
import pyttsx3

# 初始化 pyttsx3 引擎
engine = pyttsx3.init()

# 获取当前的音量、语速、语音设置
volume = engine.getProperty('volume')
rate = engine.getProperty('rate')
voices = engine.getProperty('voices')

# 输出当前设置
print(f"当前音量: {volume}")
print(f"当前语速: {rate}")
print(f"当前语音: {voices[0].name}")

# 设置新的属性
engine.setProperty('volume', 0.8)  # 设置音量为 80%
engine.setProperty('rate', 150)    # 设置语速为 150

# 设置使用不同的语音
engine.setProperty('voice', voices[1].id)  # 使用第二个语音(通常是女性语音)

# 要转换的文本
text = "你好,欢迎使用 pyttsx3 库进行文本转语音转换。"

# 播放文本
engine.say(text)

# 等待语音播放完毕
engine.runAndWait()

pyttsx3 是一个功能强大的文本转语音库,可以用于各种应用场景,如语音助手、自动化任务、盲人辅助工具等,通过简单的 API,用户可以轻松控制音量、语速和语音类型等参数,且无需依赖互联网服务,适合离线使用。

相关推荐
belldeep2 小时前
如何阅读、学习 Tcc (Tiny C Compiler) 源代码?如何解析 Tcc 源代码?
c语言·开发语言
LuckyTHP2 小时前
java 使用zxing生成条形码(可自定义文字位置、边框样式)
java·开发语言·python
mahuifa4 小时前
(7)python开发经验
python·qt·pyside6·开发经验
学地理的小胖砸5 小时前
【Python 操作 MySQL 数据库】
数据库·python·mysql
安迪小宝5 小时前
6 任务路由与负载均衡
运维·python·celery
Blossom.1185 小时前
使用Python实现简单的人工智能聊天机器人
开发语言·人工智能·python·低代码·数据挖掘·机器人·云计算
da-peng-song5 小时前
ArcGIS Desktop使用入门(二)常用工具条——数据框工具(旋转视图)
开发语言·javascript·arcgis
galaxy_strive5 小时前
qtc++ qdebug日志生成
开发语言·c++·qt
TNTLWT5 小时前
Qt功能区:简介与安装
开发语言·qt
lisw055 小时前
Python高级进阶:Vim与Vi使用指南
python·vim·excel