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. Python通過fnmatch模塊實(shí)現(xiàn)文件名匹配2. 正則表達(dá)式匹配${key}并在Java中使用的詳細(xì)方法3. 低版本IE正常運(yùn)行HTML5+CSS3網(wǎng)站的3種解決方案4. 基于Java實(shí)現(xiàn)簡(jiǎn)單貪吃蛇游戲5. jsp文件下載功能實(shí)現(xiàn)代碼6. 阿里前端開發(fā)中的規(guī)范要求7. 解決vue scoped scss 無效的問題8. Android Studio 4.0 正式發(fā)布在Ubuntu 20.04中安裝的方法9. Jsp中request的3個(gè)基礎(chǔ)實(shí)踐10. 詳談ajax返回?cái)?shù)據(jù)成功 卻進(jìn)入error的方法
