使用Speech API 原理 我們的想法是借助微軟的語音接口,所以我們肯定是要進(jìn)行調(diào)用 相關(guān)的接口。所以我們需要安裝pywin32來幫助我們完成這一個(gè)底層的交互。 示例代碼 語音引擎工廠 類似于設(shè)計(jì)模式中的“工廠模式”,pyttsx通過初始化來獲取語音引擎。當(dāng)我們第一次調(diào)用init操作的時(shí)候,會(huì)返回一個(gè)pyttsx的engine對(duì)象,再次調(diào)用的時(shí)候,如果存在engine對(duì)象實(shí)例,就會(huì)使用現(xiàn)有的,否則再重新創(chuàng)建一個(gè)。 pyttsx.init([driverName : string, debug : bool]) → pyttsx.Engine
從方法聲明上來看,第一個(gè)參數(shù)指定的是語音驅(qū)動(dòng)的名稱,這個(gè)在底層適合操作系統(tǒng)密切相關(guān)的。如下: drivename:由pyttsx.driver模塊根據(jù)操作系統(tǒng)類型來調(diào)用,默認(rèn)使用當(dāng)前操作系統(tǒng)可以使用的最好的驅(qū)動(dòng) sapi5 - SAPI5 on Windows nsss - NSSpeechSynthesizer on Mac OS X espeak - eSpeak on every other platform debug: 這第二個(gè)參數(shù)是指定要不要以調(diào)試狀態(tài)輸出,建議開發(fā)階段設(shè)置為True
引擎接口 要想很好的運(yùn)用一個(gè)庫,不了解其API是不行的。下面來看看pyttsx。engine.Engine的引擎API。 方法簽名 | 參數(shù)列表 | 返回值 | 簡(jiǎn)單釋義 |
---|
connect(topic : string, cb : callable) | topic:要描述的事件名稱;cb:回調(diào)函數(shù) | → dict | 在給定的topic上添加回調(diào)通知 | disconnect(token : dict) | token:回調(diào)失聯(lián)的返回標(biāo)記 | Void | 結(jié)束連接 | endLoop() | None | → None | 簡(jiǎn)單來說就是結(jié)束事件循環(huán) | getProperty(name : string) | name有這些枚舉值“rate, vioce,vioces,volumn | → object | 獲取當(dāng)前引擎實(shí)例的屬性值 | setProperty(name : string) | name有這些枚舉值“rate, vioce,vioces,volumn | → object | 設(shè)置當(dāng)前引擎實(shí)例的屬性值 | say(text : unicode, name : string) | text:要進(jìn)行朗讀的文本數(shù)據(jù); name: 關(guān)聯(lián)發(fā)音人,一般用不到 | → None | 預(yù)設(shè)要朗讀的文本數(shù)據(jù),這也是“萬事俱備,只欠東風(fēng)”中的“萬事俱備” | runAndWait() | None | → None | 這個(gè)方法就是“東風(fēng)”了。當(dāng)事件隊(duì)列中事件全部清空的時(shí)候返回 | startLoop([useDriverLoop : bool]) | useDriverLoop:是否啟用驅(qū)動(dòng)循環(huán) | → None | 開啟事件隊(duì)列 |
更多測(cè)試 朗讀文本 事件監(jiān)聽 打斷發(fā)音 更換發(fā)音人聲音 語速控制 音量控制 執(zhí)行一個(gè)事件驅(qū)動(dòng)循環(huán) 使用一個(gè)外部的驅(qū)動(dòng)循環(huán)
|