Python文字轉語音(研究&成品函數)
由於專案需要, 我需要將文字轉換為語音, 那麼第一步就要進行研究
什麼是語音合成技術?
語音合成(text to speech),簡稱TTS。是將文字轉化為語音的一種技術,是讓電腦模擬人類的嘴巴,透過不同的音色說出想表達的內容, 是人機對話的一部分。
TTS可以透過神經網路的設計,把文字智慧地轉化為自然語音流。極大的方便了視障患者的使用, 也提升了文本的可讀性。 TTS應用包括語音驅動的硬體以及聲音敏感系統,並常與聲音辨識程式一起使用。
現在許多廠商都推出了自己的語音合成服務或API, 大家也可以去自行查看, 本文僅做了python環境下語音合成第三方庫的調查
如何用程式碼實現?
如前文所述, 雖然市面上產品繁多, 但是作為一個開發者, 我想要一款免費的, 可程式碼調試的工具 , 經過查找材料, 我找到了gTTs庫、pyttsx3庫、speech庫都能滿足我的需求, 來做個橫向對比, 可以讓大家少走彎路。
第三方程式庫名稱 | 需要連網 | 支援中英文 | 支援日文 | 可調語速 | 像人聲程度 |
---|---|---|---|---|---|
#ggts | √ | √ | √ | X | 很像導航 |
pyttsx3 | X | # √ | X | √ | 適合閱讀小說 |
X |
- # √
- XX
gTTS函式庫
gTTS庫(Google Text-to-Speech): 用於與Google Translate 的文字轉語音API 進行互動。將語音mp3資料寫入檔案
優點: 支援包括中英日文在內的多種語言, 有Google翻譯API的加持, 人聲蠻好聽缺點: 不支援語速調節, 每次使用必須科學上網, 不能單機使用在語音播放功能, 我們選用了兩種方法
第一種是playsound庫自動播放音訊(不可調播放進度)
第二種是os函式庫呼叫系統自帶播放器(可調式進度)
請看請看
playsound庫播放& GTTS函式庫轉文字
函數# 函数功能: 用gtts库阅读文本,保存为.mp3文件后, 用系统内置的浏览器阅读出来, 打开mp3文件, 函数执行结束(播放方式为os库) def gtts_os_debug(text,mp3_filepath,language):#参数说明:参数1是朗读的文字,参数2是保存路径,参数3是数字{0英文,1中文,2日语} #大成功,可惜的是os调用自带播放器, 实际上只执行了"打开mp3"的操作, 它并不会在音频播报完后再进行下一条语句 from gtts import gTTS import os # 已知zh-tw版本违和感较高,所以我们用zh-CN来进行后续工作 if int(language) ==0 : s = gTTS(text=text, lang='en', tld='com') # s = gTTS(text=text, lang='en', tld='co.uk')#我比较喜欢美音,但是如果你喜欢英国口音可以尝试这个 elif int(language) ==1 : s = gTTS(text=text, lang='zh-CN') elif int(language) ==2 : s = gTTS(text=text, lang='ja') try: s.save(mp3_filepath) except: os.remove(mp3_filepath) print(mp3_filepath,"文件已经存在,但是没有关系!已经删掉了") s.save(mp3_filepath) print(mp3_filepath,"保存成功") os.system(mp3_filepath)#调用系统自带的播放器播放MP3 gtts_os_debug(text="I'm gtts library,from google Artificial Intelligence & Google Translate.",mp3_filepath="gtts英文测试.mp3",language=0) gtts_os_debug(text="我是gtts库, 你想听听我的声音吗",mp3_filepath="gtts中文测试.mp3",language=1) gtts_os_debug(text="真実はいつもひとつ" ,mp3_filepath="gtts日语测试.mp3",language=2)
os函式庫播放& GTTS函式庫轉文字函數
# 函数功能: 用gtts库阅读文本,保存为.mp3文件后, 用playsound库阅读出来, 阅读完毕, 函数执行结束 def gtts_debug(text,mp3_filepath,language):#参数说明:参数1是朗读的文字,参数2是保存路径,参数3是数字{0英文,1中文,2日语} #大成功,已经实现了定制化文字转语音,但是播放的playsound需要改进(playsound库本身可能会出现bug...) from gtts import gTTS from playsound import playsound import os if int(language) ==0 : s = gTTS(text=text, lang='en', tld='com') # s = gTTS(text=text, lang='en', tld='co.uk')#我比较喜欢美音,但是如果你喜欢英国口音可以尝试这个 elif int(language) ==1 : s = gTTS(text=text, lang='zh-CN') elif int(language) ==2 : s = gTTS(text=text, lang='ja') try: s.save(mp3_filepath) except: os.remove(mp3_filepath) print(mp3_filepath,"文件已经存在,但是没有关系!已经删掉了") s.save(mp3_filepath) print(mp3_filepath,"保存成功") playsound(mp3_filepath) gtts_debug(text="I'm gtts library,from google Artificial Intelligence & Google Translate.",mp3_filepath="gtts英文测试.mp3",language=0) gtts_debug(text="我是gtts库, 你想听听我的声音吗",mp3_filepath="gtts中文测试.mp3",language=1) gtts_debug(text="真実はいつもひとつ" ,mp3_filepath="gtts日语测试.mp3",language=2)pyttsx3函式庫########## pyttsx3庫### : 是Python中的文字到語音轉換庫, 它可以離線工作###優點: 可以脫機工作, 支援將語音直接朗讀, 可調節音量和速度###缺點: 初始只有英語(女)和中文(女)的語音包, 其他語言的語音包需要另外下載######請看###pyttsx3庫轉文字&自朗讀###函數###
def pyttsx3_debug(text,language,rate,volume,filename,sayit=0): #参数说明: 六个重要参数,阅读的文字,语言(0-英文/1-中文),语速,音量(0-1),保存的文件名(以.mp3收尾),是否发言(0否1是) import pyttsx3 engine = pyttsx3.init() # 初始化语音引擎 engine.setProperty('rate', rate) # 设置语速 #速度调试结果:50戏剧化的慢,200正常,350用心听小说,500敷衍了事 engine.setProperty('volume', volume) # 设置音量 voices = engine.getProperty('voices') # 获取当前语音的详细信息 if int(language)==0: engine.setProperty('voice', voices[0].id) # 设置第一个语音合成器 #改变索引,改变声音。0中文,1英文(只有这两个选择) elif int(language)==1: engine.setProperty('voice', voices[1].id) if int(sayit)==1: engine.say(text) # pyttsx3->将结果念出来 elif int(sayit)==0: print("那我就不念了哈") engine.save_to_file(text, filename) # 保存音频文件 print(filename,"保存成功") engine.runAndWait() # pyttsx3结束语句(必须加) engine.stop() # pyttsx3结束语句(必须加) pyttsx3_debug(text="我是pyttsx3, 初次见面, 给您拜个早年",language=0,rate=200,volume=0.9,filename="ptttsx3中文测试.mp3",sayit=1) pyttsx3_debug(text="I'm fake Siri, your smart voice Manager",language=1,rate=200,volume=0.9,filename="ptttsx3英文测试.mp3",sayit=1)###speech庫#########speech### : 基於Windows的語音合成模組, 一行程式碼即可實現朗讀###優點: 依靠windows系統, 安裝使用究極簡單, 超級方便。 ###適合在程式碼調試過程中, 讓冰冷的AI語言來罵醒寫bug的我QAQ###缺點: 只有系統語言(中文&英文), 不支持語速調節和音頻導出##### #請看###speech轉文字###函數###
import speech speech.say("甘霖娘,又出bug了") speech.say("Don't ask me .I have no idea why bug exist again") # 如你所见, 代码编译究极简单, 而且单机, 但是!每次使用都会呼出微软语音助手...
以上是Python第三方函式庫gTTs/pyttsx3/speech怎麼使用的詳細內容。更多資訊請關注PHP中文網其他相關文章!

Python在遊戲和GUI開發中表現出色。 1)遊戲開發使用Pygame,提供繪圖、音頻等功能,適合創建2D遊戲。 2)GUI開發可選擇Tkinter或PyQt,Tkinter簡單易用,PyQt功能豐富,適合專業開發。

Python适合数据科学、Web开发和自动化任务,而C 适用于系统编程、游戏开发和嵌入式系统。Python以简洁和强大的生态系统著称,C 则以高性能和底层控制能力闻名。

2小時內可以學會Python的基本編程概念和技能。 1.學習變量和數據類型,2.掌握控制流(條件語句和循環),3.理解函數的定義和使用,4.通過簡單示例和代碼片段快速上手Python編程。

Python在web開發、數據科學、機器學習、自動化和腳本編寫等領域有廣泛應用。 1)在web開發中,Django和Flask框架簡化了開發過程。 2)數據科學和機器學習領域,NumPy、Pandas、Scikit-learn和TensorFlow庫提供了強大支持。 3)自動化和腳本編寫方面,Python適用於自動化測試和系統管理等任務。

兩小時內可以學到Python的基礎知識。 1.學習變量和數據類型,2.掌握控制結構如if語句和循環,3.了解函數的定義和使用。這些將幫助你開始編寫簡單的Python程序。

如何在10小時內教計算機小白編程基礎?如果你只有10個小時來教計算機小白一些編程知識,你會選擇教些什麼�...

使用FiddlerEverywhere進行中間人讀取時如何避免被檢測到當你使用FiddlerEverywhere...

Python3.6環境下加載Pickle文件報錯:ModuleNotFoundError:Nomodulenamed...


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

mPDF
mPDF是一個PHP庫,可以從UTF-8編碼的HTML產生PDF檔案。原作者Ian Back編寫mPDF以從他的網站上「即時」輸出PDF文件,並處理不同的語言。與原始腳本如HTML2FPDF相比,它的速度較慢,並且在使用Unicode字體時產生的檔案較大,但支援CSS樣式等,並進行了大量增強。支援幾乎所有語言,包括RTL(阿拉伯語和希伯來語)和CJK(中日韓)。支援嵌套的區塊級元素(如P、DIV),

SecLists
SecLists是最終安全測試人員的伙伴。它是一個包含各種類型清單的集合,這些清單在安全評估過程中經常使用,而且都在一個地方。 SecLists透過方便地提供安全測試人員可能需要的所有列表,幫助提高安全測試的效率和生產力。清單類型包括使用者名稱、密碼、URL、模糊測試有效載荷、敏感資料模式、Web shell等等。測試人員只需將此儲存庫拉到新的測試機上,他就可以存取所需的每種類型的清單。

EditPlus 中文破解版
體積小,語法高亮,不支援程式碼提示功能

SublimeText3 Linux新版
SublimeText3 Linux最新版

Dreamweaver Mac版
視覺化網頁開發工具