python利用google翻譯方法實(shí)例(翻譯字幕文件)
英文字幕確實(shí)讓人頭疼,因此,花了一天專門研究,用python實(shí)現(xià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)容,翻譯特定行的字幕即可,非常簡單,但是要注意編碼問題
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ò)誤。
代碼還是比較簡單,感興趣的可以在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. 解決AJAX返回狀態(tài)200沒有調(diào)用success的問題2. ASP刪除img標(biāo)簽的style屬性只保留src的正則函數(shù)3. 如何在jsp界面中插入圖片4. 爬取今日頭條Ajax請(qǐng)求5. jsp EL表達(dá)式詳解6. Ajax實(shí)現(xiàn)表格中信息不刷新頁面進(jìn)行更新數(shù)據(jù)7. jsp中sitemesh修改tagRule技術(shù)分享8. asp(vbscript)中自定義函數(shù)的默認(rèn)參數(shù)實(shí)現(xiàn)代碼9. ASP基礎(chǔ)知識(shí)VBScript基本元素講解10. JSP servlet實(shí)現(xiàn)文件上傳下載和刪除
