单位经常使用广播进行临时事项的通知(将文字转换为语音然后通过功放广播),但是市面上多数语音播放软件都是收费的,要么发音失真,要么不够稳定——经常出现莫名其妙的故障,容易给工作带来被动。学Python这么久不如动手写一款自己的语音广播软件,即使发生故障也可以自行排除。

1

界面设计

在开始动工之前当然要分析需求,我要的核心功能是将一段文字通知输入软件,然后将其转换为语音并播放出来。

这项功能虽然并不复杂,但也需要一个交互式的界面,所以决定使用Tkinter来实现这个功能。

第一步:建立一个窗体

设置标题、大小等要素,为了避免显示格式错乱将其设定为不可改变大小,代码如下:

第二步,设置一个控件

用于接受收入的文字,这里选择带滚动条的Text,代码如下:

第三步,提供选项

作为一款语音播放软件,最基本的语速、音调等风格设置还是要有的,这里使用Combobox控件提供固定选项,用户可以根据情况选择不同的发音、语速和语调。

第四步,建立功能事件的触发接口

设置三个Button控件分别用于触发“语音播放”、“文本清除”和“界面退出”功能。

最终界面效果如下:

语音播放

关于“清除”、“退出”等功能相对比较简单,这里重点对本次的核心功能——语音播放进行详细说明。

1).语音接口

文本转换语音推荐使用百度云的REST API 接口,登录网站http://ai.baidu.com/,依次进入控制台——语音技术页面,创建自己的语音应用(下图),其中AppID 、API Key 、Secret Key 三个参数在代码中会用到。

然后使用 pip install baidu-aip 安装python SDK模块,我们来看一下函数原型:

APP_ID = 'XXXXXX'

API_KEY = 'XXXXXXXXXXXXX'

SECRET_KEY = 'XXXXXXXXXXXXXXXXXXXXXX'

client = AipSpeech(APP_ID, API_KEY, SECRET_KEY)

result = client.synthesis(text, 'zh', 1, {'per':1, 'vol':15, 'pit':9, 'spd':5 })text:需要转换的文字。

per:发音人选择, 0为女声,1为男声,3为情感合成-度逍遥,4为情感合成-度丫丫,默认为普通女声。vol:音量,取值0-15,默认为5中音量

pit:音调,取值0-9,默认为5中语调。

spd:语速,取值0-9,默认为5中语速。‘zh’和1分别为语音模式和客户端类型,该两项均为固定值,不支持修改。

可以看到,我们需要的发音、音调、语速三种风格都可以通过修改参数来实现。

2).功能设计

解决了语音合成接口的问题,就可以结合界面设置来实现具体功能了。首先,要将界面中的语音风格选项与语音合成函数参数一一对应起来,这是一个典型的键与值的对应关系,使用字典这种数据结构再合适不过了。

然后对于发音风格,选取了男声、女声、混合三种模式;

最后对于音调和语速,没必要设置过细的精度等级,这里分别选取了三个跨度明显的等级进行区分。

当“播放”按钮点击时,要从Text控件中读取文本,如果文本为空则弹出提示框要求重新输入;若文本不为空则将文本转换为音频文件并使用playsound进行播放。

这里有一个问题需要特别注意,那就是在软件运行过程中,生成并播放的音频文件不可删除、不可修改、不可覆盖,所以每次转换生成的音频文件名称绝对不能重复,否则在进行多次“播放”操作时,会因为新生成的音频文件无法保存而发生故障。

3

打包封装

到目前为止,这个软件的运行要依赖于本地的python开发环境,不能方便地提供给他人使用,这里推荐Pyinstaller的第三方库来对python程序进行打包,首先进入刚才的py文件所在目录,执 行以下cmd命令。其中“-w”的作用是是不显示命令窗口,tk_voice是刚才的py文件名称。

pyinstaller -w tk_voice.py

这时,在同一目录下会生成一个dist文件夹,这里面就是打包后的程序文件了。我们运行一下其中的.exe文件,就会出现之前设计的程序界面,在文本框中输入一段测试文字:“全体人员请注意,全体人员请注意,请立即下楼集合开饭。”,点击“播放”按钮试一下效果:

插入音频————测试.mp3

最后,关于Pyinstaller的使用有几点需要注意的地方:该方法仅适用于windows系统,而且对系统版本有比较严格的要求,比如64位系统下打包的程序无法在32位系统下运行。

如果需要打包的程序中调用了外部的一些图片或其他资源文件,则需要手动复制到打包后的文件夹内,因为对于这些文件Pyinstaller不会进行打包。

使用Pyinstaller打包如果出现中途失败的情况,可能会导致原py文件内容丢失,所以打包之前最好先进行备份。

使用import导入其他库的时候尽量有选择性,不要导入整个库,不然打包后的文件会非常庞大。

python输出到语音播放_用Python写一个语音播放软件相关推荐

  1. python输出到文件乱码_解决python解析文件时输出乱码

    首先获取到json模块,encoding指定文件编码utf-8,errors报错时忽略错误,print()输出结果看看是否有问题. # -*- coding: utf-8 -*- import jso ...

  2. python输出结果空格分割_用Python编写固定宽度,以空格分隔的CSV输出

    我想使用Python的csv编写器编写一个固定宽度,空格分隔和最小引用的CSV文件. 输出示例: item1 item2 "next item1" "next item2 ...

  3. python输出转义符字符_[8] Python转义字符和切片

    1. 概述 今天我们要补充一下字符串和列表的相关内容.加粗体代表我们已经介绍的内容,斜体代表新增内容.计算机编程的原理简要介绍 集成开发环境PyCharm 变量名.数字.字符串.列表 句式 输入和输出 ...

  4. python输出结果空格分割_使用Python分割ps的输出

    在Linux上,命令ps aux输出每个统计信息具有多个列的进程列表.例如 USER PID %CPU %MEM VSZ RSS TTY STAT START TIME COMMAND ... pos ...

  5. python输出随机字母矩阵_用python生成随机矩阵

    在下面的代码中,我对一般的平方线性系统Ax=b实现了带有部分旋转的高斯消去.我测试了我的代码,它产生了正确的输出.不过,现在我正在尝试做以下事情,但我不太确定如何编码它,寻找一些帮助与此!在 我想通过 ...

  6. python输出星期名缩写_在Python中解析带有时区缩写名称的日期/时间字符串?

    小编典典 dateutil的parser.parse()接受作为关键字参数tzinfos的类型的字典{'EST': -5*3600}(即,区域名称匹配GMT以秒偏移量).因此,假设我们有,我们可以这样 ...

  7. python输出自己的名字_【Python】Python-用大写字母打印你的名字

    http://www.cnblogs.com/xiashengwang/p/4294409.html 与孩子一起编程,有个作业题:用大写字母打印你的名字. CCCC A RRRRR C C A A R ...

  8. python输出最长字符串_使用Python打印最长的字母子字符串,并打结...

    我将通过以下方式解决该问题: >让我们定义两个字符串:当前字母递增的字符串和当前最长的字符串. >两个字符串都以第一个字母初始化. (这样我们就可以随时阅读他们的最后一封信.) >然 ...

  9. python输出200以内素数_用python输出100-200间的素数怎么输出?

    满意答案 MolanXi 推荐于 2019.09.19 采纳率:44%    等级:10 已帮助:1271人 from math import ceil def sushu(x): "&qu ...

  10. python输出一首诗_用Python自动生成藏头诗

    本文首发于公众号「老肥码码码」 前几天老肥给大家介绍了有意思的藏头诗,今天我们就来自己根据输入语句实现自动生成藏头藏尾诗吧. 整个诗句生成的逻辑是这样的,先根据输入语句爬取符合要求的诗句(来自百度汉语 ...

最新文章

  1. Bootstrap 栅格系统 理解与总结
  2. boost::serialization模块指针反序列化的安全异常处理示例
  3. 内网网段范围_局域网中多网段的划分
  4. 计算图是个什么东西?一大堆的函数用法笔记
  5. ADO.NET远程访问Access数据库的连接字符串
  6. 软件版本GA,RC,alpha,beta,Build 含义
  7. JavaScript实现哈希表数据结构
  8. 334个地级市名单_中国各级行政区划数量,统计到乡镇一级
  9. PostgreSQL中文手册
  10. QT 5.12和有道词典冲突
  11. 【Python入门】Turtle海龟库:利用海龟画笔绘制正方形和圆形
  12. DOS批处理命令之echo和@命令
  13. Linux应用编程之时间编程
  14. 论印度为什么软件行业这么发达(搞笑篇)
  15. vs-cad二次开发-C#-拖动类-右键选项卡
  16. 个人完成案例之乐学成语(显示所有动物类成语的列表和每条成语的详细信息)
  17. svn 423 Locked
  18. 炼数成金数据分析课程---13、回归分析
  19. angular中copy和extend用法实例
  20. python分析比赛_世界杯:用Python分析热门夺冠球队-(附源代码)

热门文章

  1. 【OpenCV 4开发详解】两图像间的像素操作
  2. python01-变量,运算符与数据类型+位运算
  3. TechEd 2010-如何构建企业级ETL 后续补充
  4. EasyTransaction 1.3.0 发布,一站式分布式事务解决方案
  5. Angular5学习笔记 - 虚拟RestfulApi配置与使用(六)
  6. zabbix 系统搭建(LAMP环境)+keepalived LVS配置
  7. HTML5调用本地摄像头画面,拍照,上传服务器
  8. UISlider 滑竿控件
  9. 一个正在加载网页的进度条,加载完后,自动消失?
  10. ISE安装和FLASH烧录