這篇文章主要介紹了python 利用pyttsx3文字轉語音過程詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
# -*- coding: utf-8 -*-
import pyttsx3
engine = pyttsx3.init()
with open("all.txt","r",encoding="utf-8") as f:
while 1:
line = f.readline()
print(line, end = "")
engine.say(line)
engine.runAndWait()
import pyttsx3
with open("all.txt","r",encoding="utf-8") as f:
line = f.read()#檔案不大,一次性讀取
engine = pyttsx3.init()
#調整頻率
rate = engine.getProperty("rate")
engine.setProperty("rate", rate-50)
# 調整音量
volume = engine.getProperty("volume")
engine.setProperty("volume", volume+0.25)
engine.say(line)
engine.runAndWait()
安裝
pip install pyttsx3
語音引擎工廠
類似于設計模式中的“工廠模式”,pyttsx3通過初始化來擷取語音引擎。當我們第一次調用init操作的時候,會傳回一個pyttsx3的engine對象,再次調用的時候,如果存在engine對象執行個體,就會使用現有的,否則再重新建立一個。
pyttsx.init([driverName : string, debug : bool]) → pyttsx.Engine
從方法聲明上來看,第一個參數指定的是語音驅動的名稱,這個在底層适合作業系統密切相關的。如下:
1.drivename:由pyttsx3.driver子產品根據作業系統類型來調用,預設使用目前作業系統可以使用的最好的驅動
sapi5 - SAPI5 on Windows
nsss - NSSpeechSynthesizer on Mac OS X
espeak - eSpeak on every other platform
2.debug: 這第二個參數是指定要不要以調試狀态輸出,建議開發階段設定為True
引擎接口
要想很好的運用一個庫,不了解其API是不行的。下面來看看pyttsx3。engine.Engine的引擎API。
方法簽名
參數清單
傳回值
簡單釋義
connect(topic : string, cb : callable)
topic:要描述的事件名稱;cb:回調函數
→ dict
在給定的topic上添加回調通知
disconnect(token : dict)
token:回調失聯的傳回标記
Void
結束連接配接
endLoop()
None
→ None
簡單來說就是結束事件循環
getProperty(name : string)
name有這些枚舉值“rate, vioce,vioces,volumn
→ object
擷取目前引擎執行個體的屬性值
setProperty(name : string)
name有這些枚舉值“rate, vioce,vioces,volumn
→ object
設定目前引擎執行個體的屬性值
say(text : unicode, name : string)
text:要進行朗讀的文本資料; name: 關聯發音人,一般用不到
→ None
預設要朗讀的文本資料,這也是“萬事俱備,隻欠東風”中的“萬事俱備”
runAndWait()
None
→ None
這個方法就是“東風”了。當事件隊列中事件全部清空的時候傳回
startLoop([useDriverLoop : bool])
useDriverLoop:是否啟用驅動循環
→ None
開啟事件隊列
中繼資料音調
在pyttsx3.voice.Voice中,處理合成器的發音。
age
發音人的年齡,預設為None
gender
以字元串為類型的發音人性别: male, female, or neutral.預設為None
id
關于Voice的字元串确認資訊. 通過 pyttsx3.engine.Engine.setPropertyValue()來設定活動發音簽名. 這個屬性總是被定義。
languages
發音支援的語言清單,如果沒有,則為一個空的清單。
name
發音人名稱,預設為None.
更多測試
朗讀文本
import pyttsx3
engine = pyttsx3.init()
engine.say("Sally sells seashells by the seashore.")
engine.say("The quick brown fox jumped over the lazy dog.")
engine.runAndWait()
事件監聽
import pyttsx3
def onStart(name):
print "starting", name
def onWord(name, location, length):
print "word", name, location, length
def onEnd(name, completed):
print "finishing", name, completed
engine = pyttsx3.init()
engine.say("The quick brown fox jumped over the lazy dog.")
engine.runAndWait()
打斷發音
import pyttsx3
def onWord(name, location, length):
print("word", name, location, length)
if location > 10:
engine.stop()
engine = pyttsx3.init()
engine.say("The quick brown fox jumped over the lazy dog.")
engine.runAndWait()
更換發音人聲音
engine = pyttsx3.init()
voices = engine.getProperty("voices")
for voice in voices:
engine.setProperty("voice", voice.id)
engine.say("The quick brown fox jumped over the lazy dog.")
engine.runAndWait()
語速控制
engine = pyttsx3.init()
rate = engine.getProperty("rate")
engine.setProperty("rate", rate+50)
engine.say("The quick brown fox jumped over the lazy dog.")
engine.runAndWait()
音量控制
engine = pyttsx3.init()
volume = engine.getProperty("volume")
engine.setProperty("volume", volume-0.25)
engine.say("The quick brown fox jumped over the lazy dog.")
engine.runAndWait()
執行一個事件驅動循環
engine = pyttsx3.init()
def onStart(name):
print("starting", name)
def onWord(name, location, length):
print("word", name, location, length)
def onEnd(name, completed):
print("finishing", name, completed)
if name == "fox":
engine.say("What a lazy dog!", "dog")
elif name == "dog":
engine.endLoop()
engine = pyttsx3.init()
engine.say("The quick brown fox jumped over the lazy dog.", "fox")
engine.startLoop()
使用一個外部的驅動循環
engine = pyttsx3.init()
engine.say("The quick brown fox jumped over the lazy dog.", "fox")
engine.startLoop(False)
# engine.iterate() must be called inside externalLoop()
externalLoop()
engine.endLoop()
以上就是本文的全部内容,希望對大家的學習有所幫助,也希望大家多多支援愛蒂網。