news 2026/6/26 12:08:06

【学习心得】Python好库推荐——pyttsx3

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
【学习心得】Python好库推荐——pyttsx3

pyttsx3(Python Text-to-Speech eXtended version 3)是一个跨平台的 Python 库,用于将文本转换为语音(Text-to-Speech, TTS)。它可以在不依赖互联网连接的情况下,在本地将文本朗读出来,支持 Windows、macOS 和 Linux 系统。

一、安装

pip install pyttsx3

如果使用的是Linux系统,还需要额外安装espeak

sudo apt-get install espeak

如果语音输出还是不能正常工作,那么就需要安装espeak-ng和libespeak1

sudo apt update && sudo apt install espeak-ng libespeak1

二、使用

官方PyPI链接:官方介绍

1、简单的快速使用示例:

import pyttsx3 # 初始化引擎 engine = pyttsx3.init() # 设置要朗读的文本 engine.say("你好,我是Python文本转语音引擎") # 开始朗读并等待完成 engine.runAndWait()

2、关键用法速查表

名称类型作用用法示例备注 / 返回值
pyttsx3.init()函数初始化 TTS 引擎(离线)engine = pyttsx3.init()返回Engine实例;自动选择平台后端(SAPI5/macOS/Linux)
pyttsx3.EngineTTS 引擎主对象init()返回所有语音操作均通过此对象进行
engine.say(text)方法将文本加入播报队列engine.say("Hello")非阻塞;需调用runAndWait()才会发声
engine.save_to_file(text, filename)方法将文本合成并保存为音频文件engine.save_to_file("Hi", "output.wav")文件格式通常为.wav必须调用runAndWait()才生效
engine.runAndWait()方法执行队列中的所有任务并等待完成engine.runAndWait()阻塞式调用;用于触发播放或保存
engine.stop()方法立即停止当前及后续播报engine.stop()中断正在运行的runAndWait()
engine.getProperty(name)方法获取引擎属性值rate = engine.getProperty('rate')常用属性:'rate'(语速)、'volume'(音量 0.0–1.0)、'voices'(语音列表)
engine.setProperty(name, value)方法设置引擎属性engine.setProperty('rate', 200)属性名区分大小写;设置无效值可能被忽略
engine.getProperty('voices')方法获取系统支持的语音列表voices = engine.getProperty('voices')返回list[Voice];每个Voice包含id,name,languages
engine.setProperty('voice', voice_id)方法切换语音engine.setProperty('voice', voices[0].id)voice_id必须来自有效Voice.id
Voice.id属性语音唯一标识符v.id用于setProperty('voice', ...);不可读但可设
Voice.name属性语音显示名称v.name'Microsoft Huihui Desktop - Chinese (Simplified)'
Voice.languages属性支持的语言标签v.languages可能为['zh-CN'][b'\x05z\x04h\x04'](macOS 编码)等;判断中文需谨慎
engine.connect(event, callback)方法绑定播报事件回调engine.connect('finished-utterance', on_end)事件类型:
'started-utterance'
'finished-utterance'
'started-word'(部分平台支持)
engine.startLoop(useDriverLoop=False)
engine.endLoop()
方法手动控制事件循环(高级)engine.startLoop(False)
# 自定义逻辑
engine.endLoop()
一般不需要使用;仅在 GUI 或异步环境中替代runAndWait()

3、设置参数和音色

import pyttsx3 # 初始化 TTS 引擎 engine = pyttsx3.init() # 设置语音参数(可选) engine.setProperty('rate', 150) # 语速(默认约200) engine.setProperty('volume', 0.9) # 音量(0.0 到 1.0) # 获取可用语音列表 voices = engine.getProperty('voices') engine.setProperty('voice', voices[1].id) # 选择第二个语音(通常是女声) # 朗读文本 engine.say("你好,欢迎使用 pyttsx3!") engine.runAndWait() # 等待语音播放完成
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/26 3:56:11

SQL约束解析

约束分类:NOT NULL 非空约束:字段必须有值UNIQUE 唯一约束:值不能重复,但允许多个 NULLPRINARY KEY 主键约束:既是 NOT NULL 又是 UNIQUEDEFAULT 默认约束: 保存数据时.如果未指定该字段的值,则采用默认值CHECK 检查约束:保证字段满足某一个值FOREIGN KEY 外键约束…

作者头像 李华
网站建设 2026/6/26 0:51:57

地铁调研12-17

今天地铁调研主要内容包括:1.跟随工人使用道尺进行巡检。主要测量内容:轨道内距,轨道水平情况。记录:/-x,毫米。2.涂油板(道岔变轨部分)的油是否还有。3.扣配件的螺栓是否松动扣配件的情况&…

作者头像 李华
网站建设 2026/6/25 17:00:22

现代软件测试工具全景对比与选型指南

随着敏捷开发与DevOps实践的普及,软件测试工具生态呈现百花齐放态势。截至2025年末,测试工具已从简单的BUG记录工具发展为覆盖自动化测试、性能监控、安全检测的完整解决方案。本文将通过功能性对比、适用场景分析及成本效益评估三个维度,为测…

作者头像 李华
网站建设 2026/6/26 2:01:08

基于 Apache POI 的体检报告 Word 生成实战文档

基于 Apache POI 的体检报告 Word 生成实战文档一 项目目标与总体设计 目标:基于模板快速生成排版规范的体检报告,支持文本替换、动态表格、图片插入,并可一键导出 PDF 用于归档与打印。技术选型: Apache POI XWPF:操作…

作者头像 李华
网站建设 2026/6/25 21:02:02

org.jetbrains.annotations的@Nullable 学习

Nullable 是 JetBrains 提供的一套用于 Java 静态分析的注解(annotations)之一,属于 org.jetbrains.annotations 包。它主要用于标注一个变量、参数、方法返回值等可能为 null,从而帮助 IDE(如 IntelliJ IDEA&#xff…

作者头像 李华
网站建设 2026/6/24 20:10:23

计算机毕业设计springboot计算机硬件自配系统 基于Spring Boot的计算机硬件配置管理系统设计与实现 Spring Boot架构下的计算机硬件自选系统开发

计算机毕业设计springboot计算机硬件自配系统839019 (配套有源码 程序 mysql数据库 论文) 本套源码可以在文本联xi,先看具体系统功能演示视频领取,可分享源码参考。随着信息技术的飞速发展,计算机硬件市场的复杂性和多样性不断增加…

作者头像 李华