日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

python開發一款翻譯工具

瀏覽:58日期:2022-07-08 16:23:49

最近,某水果手機廠在萬眾期待中開了一場沒有發布萬眾期待的手機產品的發布會,發布了除手機外的其他一些產品,也包括最新的水果14系統。幾天后,更新了系統的吃瓜群眾經過把玩突然發現新系統里一個超有意思的功能——翻譯,比如這種:

python開發一款翻譯工具

奇怪的翻譯知識增加了!

相比常見的翻譯工具,同聲翻譯工具更具有實用價值,想想不精通其他語言就能和歪果朋友無障礙交流的場景,真是一件美事,不如自己動手實現個工具備用!一個同聲翻譯工具,邏輯大概可以是先識別,而后翻譯,翻譯能否成功,識別的準確率是個關鍵因素。為了降低難度,我決定分兩次完成工具開發。首先來實現試試語音識別的部分。

輕車熟路,本次的demo繼續調用有道智云API,實現實時語音識別。

效果展示

先看看界面和結果哈:

可以選擇多種語音,這里只寫了四種常見的:

python開發一款翻譯工具

偶分別測試的中文、韓文、英文。看著還不錯哦~

python開發一款翻譯工具

調用API接口的準備工作

首先,是需要在有道智云的個人頁面上創建實例、創建應用、綁定應用和實例,獲取調用接口用到的應用的id和密鑰。具體個人注冊的過程和應用創建過程詳見文章分享一次批量文件翻譯的開發過程

python開發一款翻譯工具

開發過程詳細介紹

下面介紹具體的代碼開發過程。

首先是根據實時語音識別文檔來分析接口的輸入輸出。接口設計的目的是對連續音頻流的實時識別,轉換成文本信息并返對應文字流,因此通信采用websocket,調用過程分為認證、實時通信兩階段。

在認證階段,需發送以下參數:

參數 類型 必填 說明 示例 appKey String 是 已申請的應用ID ID salt String 是 UUID UUID curtime String 是 時間戳(秒) TimeStamp sign String 是 加密數字簽名。 sha256 signType String 是 數字簽名類型 v4 langType String 是 語言選擇,參考支持語言列表 zh-CHS format String 是 音頻格式,支持wav wav channel String 是 聲道,支持1(單聲道) 1 version String 是 api版本 v1 rate String 是 采樣率 16000

簽名sign生成方法如下:signType=v4;sign=sha256(應用ID+salt+curtime+應用密鑰)。

認證之后,就進入了實時通信階段,發送音頻流,獲取識別結果,最后發送結束標志結束通信,這里需要注意的是,發送的音頻最好是16bit位深的單聲道、16k采樣率的清晰的wav音頻文件,這里我開發時最開始因為音頻錄制設備有問題,導致音頻效果極差,接口一直返回錯誤碼304(手動捂臉)。

Demo開發:

這個demo使用python3開發,包括maindow.py,audioandprocess.py,recobynetease.py三個文件。界面部分,使用python自帶的tkinter庫,來進行語言選擇、錄音開始、錄音停止并識別的操作。audioandprocess.py實現了錄音、音頻處理的邏輯,最后通過recobynetease.py中的方法來調用實時語音識別API。

1.界面部分:

主要元素:

root=tk.Tk()root.title('netease youdao translation test')frm = tk.Frame(root)frm.grid(padx=’80’, pady=’80’)# label1=tk.Label(frm,text='選擇待翻譯文件:')# label1.grid(row=0,column=0)label=tk.Label(frm,text=’選擇語言類型:’)label.grid(row=0,column=0)combox=ttk.Combobox(frm,textvariable=tk.StringVar(),width=38)combox['value']=lang_type_dictcombox.current(0)combox.bind('<<ComboboxSelected>>',get_lang_type)combox.grid(row=0,column=1)btn_start_rec = tk.Button(frm, text=’開始錄音’, command=start_rec)btn_start_rec.grid(row=2, column=0)lb_Status = tk.Label(frm, text=’Ready’, anchor=’w’, fg=’green’)lb_Status.grid(row=2,column=1)btn_sure=tk.Button(frm,text='結束并識別',command=get_result)btn_sure.grid(row=3,column=0)root.mainloop()

2.音頻錄制部分,引入pyaudio庫(需通過pip安裝)來調用音頻設備,錄制接口要求的wav文件,并通過wave庫存儲文件:

def __init__(self, audio_path, language_type,is_recording): self.audio_path = audio_path, self.audio_file_name=’’ self.language_type = language_type, self.language=language_dict[language_type] print(language_dict[language_type]) self.is_recording=is_recording self.audio_chunk_size=1600 self.audio_channels=1 self.audio_format=pyaudio.paInt16 self.audio_rate=16000def record_and_save(self): self.is_recording = True # self.audio_file_name=self.audio_path+’/recordtmp.wav’ self.audio_file_name=’/recordtmp.wav’ threading.Thread(target=self.record,args=(self.audio_file_name,)).start()def record(self,file_name): print(file_name) p=pyaudio.PyAudio() stream=p.open( format=self.audio_format, channels=self.audio_channels, rate=self.audio_rate, input=True, frames_per_buffer=self.audio_chunk_size ) wf = wave.open(file_name, ’wb’) wf.setnchannels(self.audio_channels) wf.setsampwidth(p.get_sample_size(self.audio_format)) wf.setframerate(self.audio_rate) # 讀取數據寫入文件 while self.is_recording: data = stream.read(self.audio_chunk_size) wf.writeframes(data) wf.close() stream.stop_stream() stream.close() p.terminate()

3.翻譯接口調用部分:

def recognise(filepath,language_type): global file_path file_path=filepath nonce = str(uuid.uuid1()) curtime = str(int(time.time())) signStr = app_key + nonce + curtime + app_secret print(signStr) sign = encrypt(signStr) uri = 'wss://openapi.youdao.com/stream_asropenapi?appKey=' + app_key + '&salt=' + nonce + '&curtime=' + curtime + '&sign=' + sign + '&version=v1&channel=1&format=wav&signType=v4&rate=16000&langType=' + language_type print(uri) start(uri, 1600)def encrypt(signStr): hash = hashlib.sha256() hash.update(signStr.encode(’utf-8’)) return hash.hexdigest()def on_message(ws, message): result=json.loads(message) try: resultmessage1 = result[’result’][0] resultmessage2 = resultmessage1['st'][’sentence’] print(resultmessage2) except Exception as e: print(’’)def on_error(ws, error): print(error)def on_close(ws): print('### closed ###')def on_open(ws): count = 0 file_object = open(file_path, ’rb’) while True: chunk_data = file_object.read(1600) ws.send(chunk_data, websocket.ABNF.OPCODE_BINARY) time.sleep(0.05) count = count + 1 if not chunk_data: break print(count) ws.send(’{'end': 'true'}’, websocket.ABNF.OPCODE_BINARY)def start(uri,step): websocket.enableTrace(True) ws = websocket.WebSocketApp(uri,on_message=on_message,on_error=on_error,on_close=on_close) ws.on_open = on_open ws.run_forever()

總結

有道智云提供的接口一如既往的好用,這次開發主要的精力全都浪費在了由于我自己錄制的音頻質量差而識別失敗的問題上,音頻質量ok后,識別結果準確無誤,下一步就是拿去翻譯了,有了有道智云API,實現實時翻譯也可以如此簡單!

以上就是python開發一款翻譯工具的詳細內容,更多關于python開發翻譯工具的資料請關注好吧啦網其它相關文章!

標簽: Python 編程
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
99日韩精品| 亚洲女同一区| 亚洲一区二区三区中文字幕在线观看| 神马日本精品| 欧美激情另类| 日韩伦理在线一区| 国产白浆在线免费观看| 色欧美自拍视频| 日韩中文欧美| 久久久久国产精品一区二区| 久久精品不卡| 免费精品国产| 99国产精品久久久久久久成人热| 亚洲欧洲一区二区天堂久久| 久久不射网站| 婷婷六月综合| 视频一区欧美日韩| 日韩毛片网站| 国产精品亲子伦av一区二区三区| 国产精品igao视频网网址不卡日韩 | 婷婷成人av| 日韩高清不卡一区二区| 国产欧美日韩免费观看| 国产91在线播放精品| 久久久蜜桃一区二区人| 婷婷综合社区| 国产视频欧美| 日本亚洲最大的色成网站www| 欧美另类中文字幕 | 秋霞影院一区二区三区| 午夜影院欧美| 午夜天堂精品久久久久| 国产精品一区二区精品视频观看| 久久久久久久久成人| 美女网站视频一区| 蘑菇福利视频一区播放| 久久国产欧美日韩精品| 黄色在线观看www| 欧美日韩在线播放视频| 蜜臀久久99精品久久久画质超高清| 欧美中文一区| 毛片在线网站| 男人天堂欧美日韩| 国产精品一国产精品| 成人小电影网站| 久久福利影视| 久久不卡日韩美女| 日韩电影二区| 视频在线观看国产精品| 麻豆中文一区二区| 亚洲一本视频| 国产欧美日韩在线观看视频| 中国字幕a在线看韩国电影| 欧美日韩国产一区二区三区不卡| 婷婷精品久久久久久久久久不卡| 高清精品久久| 日韩在线观看一区二区| 免费一级欧美片在线观看网站| 九色porny丨国产首页在线| 亚洲黄色影院| 欧美aa在线视频| 午夜精品免费| 你懂的亚洲视频| 视频一区视频二区中文字幕| 精品高清久久| 亚洲乱码一区| 欧美精品日日操| 91成人小视频| 91精品蜜臀一区二区三区在线| 日韩在线视频一区二区三区| 日韩欧美一区免费| 777久久精品| 一区在线免费| 97精品在线| 国产视频网站一区二区三区| 伊人成人网在线看| 日韩av免费大片| 日本午夜免费一区二区| 午夜免费一区| 福利一区二区三区视频在线观看| 亚洲日本国产| 国产一在线精品一区在线观看| 久久99久久人婷婷精品综合| 99视频一区| 91一区二区三区四区| 91成人在线| 六月婷婷一区| 91久久久精品国产| 亚洲精品成人图区| 久久av网址| 日韩精品高清不卡| 黑丝一区二区三区| 久久久久99| 国产一区不卡| 欧美一级网址| 亚洲午夜免费| 黑丝美女一区二区| 91亚洲国产高清| 欧美精品国产一区| 蜜臀av性久久久久蜜臀aⅴ流畅 | 亚洲在线观看| 播放一区二区| 成人午夜网址| 国产精品毛片久久久| 一级成人国产| 国产女优一区| 欧美日韩国产亚洲一区| 韩国三级一区| 国产精东传媒成人av电影| 婷婷亚洲成人| 久久亚洲色图| 精品中文字幕一区二区三区av| 青青青免费在线视频| 精品国产精品久久一区免费式 | 99精品在线| 成人亚洲一区| 国语精品一区| 动漫av一区| 成人国产精品一区二区网站| 国产精品欧美在线观看| 欧美亚洲一级| 国产亚洲字幕| 国产精品magnet| 精品黄色一级片| 精品视频在线你懂得| 国产欧美一区二区三区米奇| 欧美一区二区三区久久| 国产九一精品| 国产精品观看| 久久久久观看| 久久久久久夜| 久久视频一区| 欧美精品一区二区三区精品| 在线视频精品| 欧美日韩国产免费观看| 精品91久久久久| 免费欧美在线视频| 日韩中文字幕无砖| 国产私拍福利精品视频二区| 欧美黑人巨大videos精品| 鲁大师精品99久久久| 岛国av在线播放| 精品成人免费一区二区在线播放| 亚洲国内欧美| 在线亚洲激情| 偷拍亚洲精品| 国产精品**亚洲精品| 国产传媒在线| 亚洲精品一区二区在线看| 蜜桃视频免费观看一区| 免费在线欧美视频| 欧美亚洲tv| 国模精品一区| 蜜臀91精品国产高清在线观看| 乱人伦精品视频在线观看| 日韩av影院| 精品久久久网| 不卡一区2区| 中文精品电影| 欧美激情视频一区二区三区在线播放| 国产精品黑丝在线播放| 婷婷久久一区| 日韩精品国产精品| 国产在视频一区二区三区吞精| 免费观看不卡av| 亚洲欧美日韩精品一区二区 | 亚洲小说欧美另类婷婷| 蜜臀国产一区二区三区在线播放| 国产精品综合| 成人午夜国产| 亚洲午夜久久| 国产一区国产二区国产三区| 91精品福利| 欧美亚洲一区二区三区| 私拍精品福利视频在线一区| 亚洲视频国产| 国产精品一二| 久久精品亚洲人成影院| 中文字幕日本一区| 精品国产91| 丝袜a∨在线一区二区三区不卡| 国产精品久久久久久妇女| 国精品一区二区| 91福利精品在线观看| 久久久成人网| 欧美日本久久| 亚洲大全视频| 国产精品大片| 国产视频一区三区| 欧美国产中文高清| 好看的av在线不卡观看| 欧美亚洲色图校园春色| 久久久噜噜噜| 国产精品一区三区在线观看| 亚洲福利精品| 国产精品白丝久久av网站| 欧美大黑bbbbbbbbb在线| 国产亚洲久久| 中文精品在线| 国产h片在线观看|