python利用google翻譯方法實(shí)例(翻譯字幕文件)
英文字幕確實(shí)讓人頭疼,因此,花了一天專門研究,用python實(shí)現(xiàn)了比較簡(jiǎn)單的翻譯代碼。僅有幾十行
首先加載模塊
pip uninstall googletransgit clone https://github.com/BoseCorp/py-googletrans.gitcd ./py-googletrans && python setup.py install
使用測(cè)試
from googletrans import Translator# 實(shí)例化translator = Translator(service_urls=[’translate.google.cn’])content = ’Today is a gooday’print(translator.translate(content, dest=’zh-CN’).text.encode(’utf-8’).decode(’utf-8’))
輸出沒問題就行
思路:
按行讀取文件內(nèi)容,翻譯特定行的字幕即可,非常簡(jiǎn)單,但是要注意編碼問題
from googletrans import Translator# encoding=utf-8import argparsedef main(args): # 實(shí)例化 translator = Translator(service_urls=[’translate.google.cn’]) f = open(args.fs, ’r+’, encoding='utf-8') flist = f.readlines() f = open(args.fs, ’w+’, encoding='utf-8') f.writelines(flist) for x in range(4, len(flist)): if x % 4 == 0: print(x) flist[x] = translator.translate(flist[x], dest=’zh-CN’).text.encode(’utf-8’).decode(’utf-8’) + 'n' print(translator.translate(flist[x], dest=’zh-CN’).text.encode(’utf-8’).decode(’utf-8’)) f = open(args.fs, ’w+’, encoding='utf-8') f.writelines(flist)if __name__ == ’__main__’: parser = argparse.ArgumentParser(usage='it’s usage tip.', description='help info.') parser.add_argument('--fs', type=str, required=True, help='the fileloacation') args = parser.parse_args() main(args)
使用示范:
python tran.py --fs 'D:xiaxiaxiapycharmtexta.vtt'
注意事項(xiàng)
讀行,按行處理,然后寫入和打開都要注意編碼,寫入的時(shí)候還得再最后加個(gè)換行符n 這樣才不會(huì)有錯(cuò)誤。
代碼還是比較簡(jiǎn)單,感興趣的可以在io處理和并發(fā)上還可以再優(yōu)化。
總結(jié)
到此這篇關(guān)于python利用google翻譯(翻譯字幕文件)的文章就介紹到這了,更多相關(guān)python用google翻譯字幕文件內(nèi)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!
相關(guān)文章:
1. asp文件用什么軟件編輯2. PHP基礎(chǔ)之生成器4——比較生成器和迭代器對(duì)象3. CentOS郵箱服務(wù)器搭建系列——SMTP服務(wù)器的構(gòu)建( Postfix )4. Docker 啟動(dòng)Redis 并設(shè)置密碼的操作5. ASP新手必備的基礎(chǔ)知識(shí)6. Vue axios獲取token臨時(shí)令牌封裝案例7. vue+element開發(fā)一個(gè)谷歌插件的全過程8. Spring如何替換掉默認(rèn)common-logging.jar9. 利用CSS制作3D動(dòng)畫10. JAVA 實(shí)現(xiàn)延遲隊(duì)列的方法

網(wǎng)公網(wǎng)安備