成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久

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

python調用有道智云API實現文件批量翻譯

瀏覽:10日期:2022-07-08 16:04:57

最近工作過程中,需要對一批文件進行漢譯英的翻譯,對單個文檔手工復制、粘貼的翻譯方式過于繁瑣,考慮到工作的重復性和本人追求提高效率、少動手(懶),想通過調用已有的接口的方法,自己實現一個批量翻譯工具,一勞永逸。在網上找了幾款翻譯API,通過對比翻譯的結果和學習成本,選擇了有道智云的服務,自己開發了一個批量翻譯的小軟件。詳細記錄一下使用和開發過程,后面的小伙伴們有相關需求,可以參考。

批量文檔翻譯工具的使用

我這里開發批量文檔翻譯工具使用python作為開發工具,功能如下:

     1)通過文件夾選擇多個文檔;

     2)可以將多個文檔的翻譯結果存到目標文件夾下。

話不多說,看圖↓↓↓↓↓

python調用有道智云API實現文件批量翻譯

部分翻譯結果展示(涉及工作內容的保密性,這里用荷塘月色作為樣例):

python調用有道智云API實現文件批量翻譯

開發過程

下面開始詳細介紹調用有道智云API接口的步驟和軟件開發的過程:

1、個人開發者賬號注冊

首先,需要注冊個人的開發者賬號。

在官網點擊注冊,然后填寫個人資料。即可完成注冊,官網地址:http://ai.youdao.com/gw.s#/

python調用有道智云API實現文件批量翻譯

2、 創建應用和實例

注冊成功并登錄后個人中心頁面如下圖,有道智云提供了自然語言翻譯、文字識別、語音合成、語音測評等服務接口。 這些服務接口都是通過以實例的方式運行的,通過應用進行管理的。需要分別創建實例、創建應用,通過應用獲取應用ID和應用密鑰等信息。

python調用有道智云API實現文件批量翻譯

我這里用到的是自然語言翻譯服務,首先,需要分別創建一個應用、創建一個自然語音翻譯的實例;其次,需要將實例綁定到應用上。最后,就可以通過應用的應用ID、應用密鑰調用自然語音翻譯api接口了。有道平臺會對不同的實例、應用的使用情況進行記錄、分析、收費。剛剛注冊的體驗者會有免費體驗字數和50元的體驗金哦(加客服貌似還會有額外的50元的)。

創建實例的步驟:

根據使用需求,選擇對應服務(“自然語言翻譯”/“文字識別OCR”/“語音合成TTS”/“語音識別ASR”/“智能語音評測”/“多平臺編輯器”)->“創建實例”,按步驟完成實例創建。

python調用有道智云API實現文件批量翻譯

創建應用并綁定實例(應用接口分為三種:API、安卓、ios接口):

點擊“應用管理”->“我的應用”->“創建應用”,填寫應用名稱等相關信息,選擇接入方式,并綁定我們所創建的實例,完成應用創建。我們這里用到的是API方式接入,安卓、ios接口需要根據提示填寫相應的信息,詳見官網新手指南。

python調用有道智云API實現文件批量翻譯

應用創建成功后,可獲取應用ID(appKey)和應用密鑰等信息,這些信息是調用API接口必不可少的參數。

3、接口調用及代碼實現

1)API接口介紹

下面介紹API接口的調用方法

文本翻譯API HTTPS地址:https://openapi.youdao.com/api

調用規則:在調用集成文本翻譯API時,需遵循以下規則。

規則 描述 傳輸方式 HTTPS 請求方式 GET/POST 字符編碼 統一使用UTF-8 編碼 請求格式 表單 響應格式 JSON

調用傳參:調用API需要向接口發送以下字段來訪問服務。

字段名 類型 含義 必填 備注 q text 待翻譯文本 True 必須是UTF-8編碼 from text 源語言 True 參考下方 支持語言 (可設置為auto) to text 目標語言 True 參考下方 支持語言 (可設置為auto) appKey text 應用ID True 可在 應用管理 查看 salt text UUID True UUID sign text 簽名 True sha256(應用ID+input+salt+curtime+應用密鑰) signType text 簽名類型 True v3 curtime text 當前UTC時間戳(秒) true TimeStamp ext text 翻譯結果音頻格式,支持mp3 false mp3 voice text 翻譯結果發音選擇 false 0為女聲,1為男聲。默認為女聲 strict text 是否嚴格按照指定from和to進行翻譯:true/false false 如果為false,則會自動中譯英,英譯中。默認為false

簽名生成方法如下:signType=v3;sign=sha256(應用ID+input+salt+curtime+應用密鑰);其中,input的計算方式為:input=q前10個字符 + q長度 + q后10個字符(當q長度大于20)或 input=q字符串(當q長度小于等于20);

返回結果格式:返回的結果是json格式,具體說明如下:

字段名 類型 含義 備注 errorCode text 錯誤返回碼 一定存在 query text 源語言 查詢正確時,一定存在 translation Array 翻譯結果 查詢正確時,一定存在 basic text 詞義 基本詞典,查詞時才有 web Array 詞義 網絡釋義,該結果不一定存在 l text 源語言和目標語言 一定存在 dict text 詞典deeplink 查詢語種為支持語言時,存在 webdict text webdeeplink 查詢語種為支持語言時,存在 tSpeakUrl text 翻譯結果發音地址 翻譯成功一定存在,需要應用綁定語音合成實例才能正常播放 否則返回110錯誤碼 speakUrl text 源語言發音地址 翻譯成功一定存在,需要應用綁定語音合成實例才能正常播放 否則返回110錯誤碼 returnPhrase Array 單詞校驗后的結果 主要校驗字母大小寫、單詞前含符號、中文簡繁體

當返回的結果errorCode為 0 時說明調用成功,不為0時,則會出現不同含義的錯誤碼。詳細含義可查閱官方開發文檔。

2)批量文檔翻譯開發

批量翻譯demo使用python3實現,為了方便測試,我用tkinter做了簡單的界面,用來讀取待翻譯文檔,指定結果存儲路徑,為了最大化簡化開發過程,降低測試的時間成本,目前只實現了讀取.txt類型文件的方法。

整個demo分為三個文件,mainwindow.py,translate.py和translatetool.py,mainwindow為UI部分的代碼,translate中實現了批量讀取文檔并翻譯保存的邏輯,translatetool為根據示例代碼改造后的翻譯方法,需調用其他平臺API時,亦可封裝相應方法,增加了項目的擴展性。

mainwindow的元素如下:

root=tk.Tk()root.title('netease youdao translation test')frm = tk.Frame(root)frm.grid(padx=’50’, pady=’50’)btn_get_file = tk.Button(frm, text=’選擇待翻譯文件’, command=get_files)btn_get_file.grid(row=0, column=0, ipadx=’3’, ipady=’3’, padx=’10’, pady=’20’)text1 = tk.Text(frm, width=’40’, height=’10’)text1.grid(row=0, column=1)btn_get_result_path=tk.Button(frm,text=’選擇翻譯結果路徑’,command=set_result_path)btn_get_result_path.grid(row=1,column=0)text2=tk.Text(frm,width=’40’, height=’2’)text2.grid(row=1,column=1)btn_sure=tk.Button(frm,text='翻譯',command=translate_files)btn_sure.grid(row=2,column=1)

其中translate_files()方法最終調用了translate類的translate_files()方法:

def translate_files(): if translate.file_paths: translate.translate_files() tk.messagebox.showinfo('提示','搞定') else : tk.messagebox.showinfo('提示','無文件')

類translate定義如下:

import osfrom translatetool import connectclass Translate(): def __init__(self,name,file_paths,result_root_path,trans_type): self.name=name self.file_paths=file_paths# 待翻譯文件路徑 self.result_root_path=result_root_path# 翻譯結果存儲路徑 self.trans_type=trans_type # 翻譯過程:讀取文件-掉用有道api-解析返回信息-保存 def translate_files(self): for file_path in self.file_paths: file_name=os.path.basename(file_path) file_content=open(file_path,encoding=’utf-8’).read() trans_reult=self.translate_use_netease(file_content) resul_file=open(self.result_root_path+’/result_’+file_name,’w’).write(trans_reult) def translate_use_netease(self,file_content): result=’,’.join(connect(file_content,’zh-CH’,’EN’)) # 翻譯API返回結果為一個數組 return result

調用有道API主要方法為connect(),根據API的簽名信息等要求組成data并發送請求,解析返回的json:

# input輸入待翻譯字段,fromlanguage待翻譯的語言,tolanguage翻譯成的目標語言# 返回翻譯的字段def connect(inputtext,fromlanguage,tolanguage): q=inputtext data = {} data[’from’] = fromlang data[’to’] = tolang data[’signType’] = ’v3’ curtime = str(int(time.time())) data[’curtime’] = curtime salt = str(uuid.uuid1()) signStr = APP_KEY + truncate(q) + salt + curtime + APP_SECRET sign = encrypt(signStr) data[’appKey’] = APP_KEY data[’q’] = q data[’salt’] = salt data[’sign’] = sign print(data) response = do_request(data) print(response.content) j = json.loads(str(response.content, encoding='utf-8'))['translation'] return j

完整demo代碼地址:https://github.com/LemonQH/BatchFileTraslationProgram/tree/master

得益于API的學習成本之低,接口調用部分的開發過程十分順利,僅有一個小插曲,最開始調用API總是返回錯誤碼206(即時間戳錯誤),最后發現是我的系統時間比標準時間慢了十分鐘 - - #

總結

對于我此次的需要翻譯的文檔需求來說,有道智云贈送的字數和賬戶額度,已經夠用了,但是如果想長期的使用下去,還是要付費的。最后發現,有道智云在個人主頁中還提供了按小時統計當日實例調用次數和查詢字符數和按天統計歷史天數內實例的調用次數和字符數,對有需求的小伙伴,還可以記錄查看自己接口的翻譯量、實時調用量等狀態。

如上是我整個demo的開發過程。整體來說從注冊到調用有道智云API的過程還是比較順利的,而且每一步都有官方的詳細文檔可以參照。以至于主要開發時間都分配給了tkinter排版(順便吐槽下tkinter的“好用” :p)。

以上就是python調用有道智云API實現文件批量翻譯的詳細內容,更多關于python 文件批量翻譯的資料請關注好吧啦網其它相關文章!

標簽: Python 編程
相關文章:
成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久
亚洲黄色视屏| 免费成人在线网站| 经典三级在线一区| 久久婷婷丁香| 亚洲一区二区影院| 99精品国产福利在线观看免费| 国产日韩欧美一区二区三区乱码 | 国产精品剧情在线亚洲| 国产成人av影院| 欧美一区二区三区电影| 国产高清成人在线| 日韩视频免费观看高清完整版在线观看 | 精品成人佐山爱一区二区| 国产资源精品在线观看| 在线成人免费观看| 国产精品一卡二卡| 精品国产凹凸成av人导航| 99riav久久精品riav| 久久久久国产一区二区三区四区| 成人激情黄色小说| 久久亚洲捆绑美女| 欧美精品首页| 亚洲精品乱码久久久久久久久| 国产日韩高清一区二区三区在线| 一区二区高清视频在线观看| 午夜亚洲视频| 日本网站在线观看一区二区三区 | 色婷婷狠狠综合| 免费人成精品欧美精品| 在线观看视频一区二区| 韩国毛片一区二区三区| 日韩欧美一区二区在线视频| av电影在线观看完整版一区二区| 国产亚洲综合性久久久影院| 国产综合精品一区| 一区二区三区四区激情| 久久看片网站| 精彩视频一区二区三区| 精品久久久久久久人人人人传媒 | 视频在线观看91| 欧美专区日韩专区| 国产精品资源网站| 久久久久久久久蜜桃| 亚洲无玛一区| 亚洲h精品动漫在线观看| 在线视频中文字幕一区二区| 国产在线日韩欧美| 久久久不卡影院| 亚洲日本国产| 奇米影视在线99精品| 日韩欧美国产wwwww| 欧美三级视频| 午夜天堂影视香蕉久久| 91精品国产色综合久久久蜜香臀| 色综合咪咪久久| 一区二区三区美女视频| 欧美日韩黄色一区二区| 91麻豆免费看片| 亚洲午夜在线视频| 69p69国产精品| 欧美黄在线观看| 亚洲已满18点击进入久久| 欧美制服丝袜第一页| av影院午夜一区| 一区二区三区资源| 欧美精品久久天天躁| 欧美视频成人| 日韩电影在线一区二区三区| 91精品国产高清一区二区三区蜜臀 | 丰满少妇久久久久久久| 久久九九久久九九| 国产模特精品视频久久久久| 国产福利一区二区三区视频在线| 国产精品久久久久婷婷二区次| 欧洲色大大久久| 欧美日本三区| 青娱乐精品在线视频| 久久九九久久九九| 色婷婷久久一区二区三区麻豆| 波多野洁衣一区| 香蕉影视欧美成人| 久久久www成人免费毛片麻豆| 久久国产一区| 91免费视频网址| 免费欧美在线视频| 国产精品免费aⅴ片在线观看| 欧美熟乱第一页| 国产一区二区三区自拍| 六月丁香综合在线视频| 亚洲欧洲在线观看av| 制服.丝袜.亚洲.中文.综合| 国产精品国产精品| 韩国成人精品a∨在线观看| 国产精品成人一区二区三区夜夜夜| 欧美亚洲国产一区在线观看网站| 97成人超碰视| 男男视频亚洲欧美| 国产精品家庭影院| 日韩一区二区三区电影在线观看 | 六月婷婷一区| 99re热这里只有精品视频| 奇米影视在线99精品| 中文字幕日本不卡| 欧美一区二区精品在线| 国产日韩亚洲欧美精品| 99久久免费视频.com| 奇米影视一区二区三区| 成人免费在线视频| 精品美女在线播放| 欧美性色aⅴ视频一区日韩精品| 国内视频精品| www.成人网.com| 九九**精品视频免费播放| 一级中文字幕一区二区| 国产欧美一区二区精品仙草咪| 欧美日韩高清不卡| 亚洲一区尤物| 亚洲视频精品| 99国产一区二区三精品乱码| 久久99精品一区二区三区| 亚洲一区在线观看网站| 日本一区二区高清| 日韩免费观看2025年上映的电影 | 日韩免费在线观看| 欧美伊人久久大香线蕉综合69| 亚洲夜间福利| 波多野结衣中文一区| 麻豆视频一区二区| 亚洲第一精品在线| 亚洲视频在线观看一区| 久久久国产精品午夜一区ai换脸| 欧美卡1卡2卡| 91成人免费网站| 翔田千里一区二区| 99成人精品| 黄色成人在线网站| 99久久久国产精品| 国产福利视频一区二区三区| 免费观看久久久4p| 亚洲成人激情av| 一级女性全黄久久生活片免费| 中文字幕av免费专区久久| 日韩区在线观看| 欧美视频在线一区| 色域天天综合网| 国产精品久久久久毛片大屁完整版 | 日本一二三不卡| 精品国产91乱码一区二区三区| 欧美日韩一区二区电影| 久久免费高清| 国产日韩欧美一区二区三区四区| 国产精品hd| 97久久精品人人澡人人爽| 国产原创一区二区| 久久疯狂做爰流白浆xx| 免费久久精品视频| 日本成人中文字幕在线视频| 亚洲一区二区三区美女| 亚洲精品美腿丝袜| 一区二区三区在线免费播放| 日韩毛片视频在线看| 国产精品国产三级国产普通话三级 | 成人av网址在线观看| 国产综合色产在线精品| 琪琪久久久久日韩精品| 热久久久久久久| 日本午夜精品一区二区三区电影| 偷拍与自拍一区| 香蕉加勒比综合久久| 五月天中文字幕一区二区| 天天综合色天天综合| 午夜av一区二区三区| 日本视频一区二区三区| 免费人成网站在线观看欧美高清| 青青草成人在线观看| 六月婷婷色综合| 国产一区二区三区美女| 国产一区二区精品在线观看| 国产盗摄女厕一区二区三区| 成人午夜视频网站| 91年精品国产| 国内精品久久国产| 一本色道精品久久一区二区三区| 国产精品视区| 色成年激情久久综合| 欧美三日本三级三级在线播放| 欧美人牲a欧美精品| 欧美一区二区三区婷婷月色| 日韩欧美国产三级电影视频| 国产性天天综合网| 成人欧美一区二区三区在线播放| 亚洲专区一二三| 婷婷一区二区三区| 精品一区二区三区日韩| 丁香婷婷综合色啪| 欧美精品v日韩精品v国产精品| 亚洲婷婷免费| 久久狠狠婷婷| 欧美福利电影网| 久久人人97超碰com|