尧图网站建设 尧图网络
  • 首页
  • 关于我们
  • 服务项目
  • 案例展示
  • 建站流程
  • 资讯中心
  • 联系我们
首页/资讯中心/详情

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

【学习心得】Python好库推荐——pyttsx3
📅 发布时间:2026/6/20 21:38:50

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.Engine类TTS 引擎主对象由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() # 等待语音播放完成

相关新闻

  • Java毕设项目:基于javaweb的学生管理系统(源码+文档,讲解、调试运行,定制等)
  • AspectJ、Spring AOP 与 Solon AOP:Java AOP 框架的三剑客
  • Qt共享内存疑难解析:从创建失败到完美解决

最新新闻

  • 2026年高端定制与普通全屋定制区别解析:黑泽玛德表现如何? - 新闻快传
  • 低查重AI教材编写工具推荐,让AI快速为你生成专业教材!
  • M68HC08 ADC编程实战:从原理到代码,掌握嵌入式感官核心
  • i.MX 6接口时序设计:从数据手册到稳定硬件的实战指南
  • 2026年6月最新欧米茄中国官方售后客户服务地址电话网点大全 - 欧米茄服务中心
  • 淮南师范学院的办学历史多久?师资力量整体水平怎么样? - 寻茫精选

日新闻

  • Visual C++运行库修复终极指南:5分钟快速解决Windows软件启动错误
  • 手把手教你构建统计局地区经济数据爬虫:从环境搭建到数据持久化全指南
  • 2026多Agent深度解析:用AI团队替代单一模型,四种架构实战落地

周新闻

  • Visual C++运行库修复终极指南:5分钟快速解决Windows软件启动错误
  • 手把手教你构建统计局地区经济数据爬虫:从环境搭建到数据持久化全指南
  • 2026多Agent深度解析:用AI团队替代单一模型,四种架构实战落地

月新闻

  • 【总结】入门篇:50句话让你记住架构核心概念
  • WeChatMsg技术方案解析:实现Mac微信数据自主管理的完整解决方案
  • WeChatMsg:革新性微信数据备份方案,打造你的专属数字记忆库

关于尧图

  • 公司简介
  • 团队介绍
  • 企业文化
  • 荣誉资质

服务项目

  • 定制开发
  • 电商建站
  • UI 设计
  • 运维服务

快速链接

  • 案例展示
  • 建站流程
  • 常见问题
  • 资讯中心

联系方式

  • 📍北京市朝阳区互联网产业园 A 座 10 层
  • 📞400-888-8888
  • ✉️contact@rkmt.cn
  • 🕐周一至周日 9:00-21:00

© 2024 北京尧图网络科技有限公司 版权所有 | 京 ICP 备 XXXXXXXX 号