日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > python >内容正文

python

python文档自动翻译

發(fā)布時間:2023/12/10 python 21 豆豆
生活随笔 收集整理的這篇文章主要介紹了 python文档自动翻译 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

目錄

概述

一、讀取Word文檔

二、讀取PDF文檔


概述

? ? ? ? 工作上的需要翻譯的文檔常用的事情,列舉使用python自動翻譯各種方法。

關鍵方法
提取文檔內(nèi)容
讀取TXT文檔

txt文檔的讀取很簡單,直接用python自帶的open()方法就好,代碼如下所示:

# 讀取TXT文檔
def read_txt(path):
????????'''實現(xiàn)TXT文檔的讀取,一次將內(nèi)容全部取出'''
????????content = ''
????????with open(path) as f:
????????????????content = f.read()
????????return content
# 也可以用readline()讀取每一行


一、讀取Word文檔

讀取Word文檔也比較簡單,導入第三方庫python-docx,安裝指令為pip install python-docx,實例代碼如下:

import docx # 安裝指令:pip install python-docxdef translate(self):'''翻譯'''# 獲取文檔對象doc = docx.Document(self.fullName)# 創(chuàng)建內(nèi)存中的word文檔對象new_doc = docx.Document()# 遍歷每一段文本for para in doc.paragraphs:# 翻譯trans = baidu_translate(para.text) # 寫入新文件new_doc.add_paragraph(para.text)new_doc.add_paragraph(trans)# 保存到本地文件new_doc.save(self.new_fullPath)

二、讀取PDF文檔

讀取PDF文檔同樣需要安裝第三方庫,主要有PyPDF2和pdfminer,這兩個庫我都有去了解,算是各有特點吧。

PyPDF2使用相對簡單,但只支持英文,對中文支持不太友好;相反pdfminer使用相對而言要復雜點,僅僅是相對而言,其支持多種語言,圖表、圖片等,功能較強大。這兩種方式我在代碼中均有實現(xiàn),其實例代碼如下:
PyPDF2

# 安裝指令:pip install pypdf2 from PyPDF2.pdf import PdfFileReaderdef translate(self):'''讀取pdf內(nèi)容,并翻譯,寫入txt文件'''f = open(self.fullPath,'rb')pdf = PdfFileReader(f)for i in range(0,pdf.getNumPages()):extractedText = pdf.getPage(i).extractText()content = extractedText.split('\n') content = self.removeBlankFromList(content) # 拼接之后的文本,如果單詞間歇超過一個空格的,認為是需要換行處理的content_list = self.enter_symbol(content)for line in content_list:trans = baidu_translate(line)self.write(line + '\n')self.write(trans)f.close()Logger().write(self.fileName + '翻譯完成,新文檔:' + self.new_fullPath)

pdfminer

# 安裝指令:pip install pdfminer3k from pdfminer.pdfparser import PDFParser,PDFDocument from pdfminer.pdfinterp import PDFResourceManager,PDFPageInterpreter from pdfminer.layout import LAParams,LTTextBoxHorizontal from pdfminer.converter import PDFPageAggregator from pdfminer.pdfinterp import PDFTextExtractionNotAlloweddef translate(self):'''讀取pdf內(nèi)容,并翻譯,寫入txt文件'''# 以二進制讀模式打開本地pdf文件fp = open(self.fullPath,'rb')# 用文件對象來創(chuàng)建一個pdf文檔分析器praser_pdf = PDFParser(fp)# 創(chuàng)建一個PDF文檔doc_pdf = PDFDocument()# 連接分析器與文檔對象praser_pdf.set_document(doc_pdf)doc_pdf.set_parser(praser_pdf)# 提供初始化密碼doc.initialize("123456"),如果沒有密碼 就創(chuàng)建一個空的字符串doc_pdf.initialize()# 檢查文檔是否提供txt轉換,不提供就無法翻譯文檔if not doc_pdf.is_extractable:Logger().write(self.fileName + '未能提取有效的文本,停止翻譯。')returnelse:# 創(chuàng)建PDF資源管理器來共享資源rsrcmgr = PDFResourceManager()# 創(chuàng)建一個PDF參數(shù)分析器laparams = LAParams()# 創(chuàng)建聚合器device = PDFPageAggregator(rsrcmgr,laparams=laparams)# 創(chuàng)建一個PDF頁面解釋器對象interpreter = PDFPageInterpreter(rsrcmgr,device)# 循環(huán)遍歷列表,每次處理一頁的內(nèi)容for page in doc_pdf.get_pages():# 使用頁面解釋器來讀取interpreter.process_page(page)# 使用聚合器獲取內(nèi)容layout = device.get_result()# 這里layout是一個LTPage對象 里面存放著 這個page解析出的各種對象 一般包括LTTextBox, LTFigure, LTImage, LTTextBoxHorizontal 等等 想要獲取文本就獲得對象的text屬性,for out in layout:# 判斷是否含有get_text()方法,圖片之類的就沒有if isinstance(out,LTTextBoxHorizontal):content = out.get_text()trans = baidu_translate(content)self.write(content)self.write(trans)Logger().write(self.fileName + '翻譯完成,新文檔:' + self.new_fullPath)

調(diào)用翻譯接口

利用python網(wǎng)絡爬蟲可以很輕松的實現(xiàn)數(shù)據(jù)爬取,這里就是利用這種“手段”實現(xiàn)翻譯功能,對此,還是要感謝這些接口提供商,感謝CCTV、鐵嶺TV。

百度翻譯

百度翻譯有反爬機制,電腦端的爬蟲會被干掉,所幸手機端可以使用,代碼如下所示:

import urllib.request import urllib.parse import json # 百度翻譯方法 def baidu_translate(content,type=1):'''實現(xiàn)百度翻譯'''baidu_url = 'http://fanyi.baidu.com/basetrans'data = {}data['from'] = 'en'data['to'] = 'zh'data['query'] = contentdata['transtype'] = 'translang'data['simple_means_flag'] = '3'data['sign'] = '94582.365127'data['token'] = 'ec980ef090b173ebdff2eea5ffd9a778'data = urllib.parse.urlencode(data).encode('utf-8')headers = {"User-Agent":"Mozilla/5.0 (Linux; Android 5.1.1; Nexus 6 Build/LYZ28E) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/63.0.3239.84 Mobile Safari/537.36"}baidu_re = urllib.request.Request(baidu_url, data, headers)baidu_response = urllib.request.urlopen(baidu_re)baidu_html = baidu_response.read().decode('utf-8')target2 = json.loads(baidu_html)trans = target2['trans']ret = ''for i in range(len(trans)):ret += trans[i]['dst'] + '\n'return ret

谷歌翻譯

首先需要一個類實現(xiàn)JS碼的生成

import execjs class Py4Js(): def __init__(self): self.ctx = execjs.compile(""" function TL(a) { var k = ""; var b = 406644; var b1 = 3293161072; var jd = "."; var $b = "+-a^+6"; var Zb = "+-3^+b+-f"; for (var e = [], f = 0, g = 0; g < a.length; g++) { var m = a.charCodeAt(g); 128 > m ? e[f++] = m : (2048 > m ? e[f++] = m >> 6 | 192 : (55296 == (m & 64512) && g + 1 < a.length && 56320 == (a.charCodeAt(g + 1) & 64512) ? (m = 65536 + ((m & 1023) << 10) + (a.charCodeAt(++g) & 1023), e[f++] = m >> 18 | 240, e[f++] = m >> 12 & 63 | 128) : e[f++] = m >> 12 | 224, e[f++] = m >> 6 & 63 | 128), e[f++] = m & 63 | 128) } a = b; for (f = 0; f < e.length; f++) a += e[f], a = RL(a, $b); a = RL(a, Zb); a ^= b1 || 0; 0 > a && (a = (a & 2147483647) + 2147483648); a %= 1E6; return a.toString() + jd + (a ^ b) }; function RL(a, b) { var t = "a"; var Yb = "+"; for (var c = 0; c < b.length - 2; c += 3) { var d = b.charAt(c + 2), d = d >= t ? d.charCodeAt(0) - 87 : Number(d), d = b.charAt(c + 1) == Yb ? a >>> d: a << d; a = b.charAt(c) == Yb ? a + d & 4294967295 : a ^ d } return a } """) def getTk(self,text): return self.ctx.call("TL",text)

調(diào)用方法如下所示:

from Py4Js import *# 谷歌翻譯方法 def google_translate(content):'''實現(xiàn)谷歌的翻譯'''js = Py4Js()tk = js.getTk(content)if len(content) > 4891: print("翻譯的長度超過限制!!!") return param = {'tk': tk, 'q': content} result = requests.get("""http://translate.google.cn/translate_a/single?client=t&sl=en &tl=zh-CN&hl=zh-CN&dt=at&dt=bd&dt=ex&dt=ld&dt=md&dt=qca&dt=rw&dt=rm&dt=ss &dt=t&ie=UTF-8&oe=UTF-8&clearbtn=1&otf=1&pc=1&srcrom=0&ssel=0&tsel=0&kc=2""", params=param) #返回的結果為Json,解析為一個嵌套列表 trans = result.json()[0]ret = ''for i in range(len(trans)):line = trans[i][0]if line != None:ret += trans[i][0]return ret

有道翻譯

有道翻譯的代碼實現(xiàn)如下所示:

import urllib.request import urllib.parse import json # 有道翻譯方法 def youdao_translate(content):'''實現(xiàn)有道翻譯的接口'''youdao_url = 'http://fanyi.youdao.com/translate?smartresult=dict&smartresult=rule'data = {}data['i']= contentdata['from'] = 'AUTO'data['to'] = 'AUTO'data['smartresult'] = 'dict'data['client'] = 'fanyideskweb'data['salt'] = '1525141473246'data['sign'] = '47ee728a4465ef98ac06510bf67f3023'data['doctype'] = 'json'data['version'] = '2.1'data['keyfrom'] = 'fanyi.web'data['action'] = 'FY_BY_CLICKBUTTION'data['typoResult'] = 'false'data = urllib.parse.urlencode(data).encode('utf-8')youdao_response = urllib.request.urlopen(youdao_url, data)youdao_html = youdao_response.read().decode('utf-8')target = json.loads(youdao_html)trans = target['translateResult']ret = ''for i in range(len(trans)):line = ''for j in range(len(trans[i])):line = trans[i][j]['tgt']ret += line + '\n'return ret

寫入文檔
寫TXT文檔

TXT文檔的寫比較簡單,代碼如下所示:

# 寫TXT文檔 def write_txt(path,content):'''實現(xiàn)TXT文檔的寫方法'''with open(path,'a+') as f:f.write(content)

寫Word文檔

Word文檔的寫就是用上面所屬的python-docx庫實現(xiàn),在上面讀取Word文檔小節(jié)中已有代碼明細,非常之簡單,這里就不在贅述。

寫PDF文檔

同上,寫PDF文檔,用PyPdf和pdfminer均可實現(xiàn),PyPDF相對而言要簡單寫,因本腳本對翻譯后的文檔只實現(xiàn)了Word和TXT的寫,方便對文檔進行編輯處理,若需要生成PDF文檔,有興趣可自行研究。

好了,以上就是關鍵技術基本描述。

總結

以上是生活随笔為你收集整理的python文档自动翻译的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 日韩大片av| 欧美又粗又长又爽做受 | 巨大黑人极品videos精品 | 国产 日韩 欧美 制服丝袜 | 黄色网战大全 | 狠狠搞视频 | 精品日韩一区二区三区四区 | 亚洲av成人无码久久精品老人 | 奇米99 | 亚洲一区二区精华 | 男人天堂欧美 | 91麻豆产精品久久久久久夏晴子 | 天天干天天干天天 | 操操操av | 嫩草视频在线 | 日本一区二区三区免费在线观看 | 欧美日本韩国在线 | 天天爽一爽 | 成人黄色av | 先锋影音中文字幕 | 黄色日韩视频 | 少妇系列av| 一区二区三区精品在线 | 午夜av在线播放 | 男人手机天堂 | 成年人看的网站 | 少妇毛片一区二区三区粉嫩av | 夜夜高潮夜夜爽 | 亚洲AV无码久久精品色三人行 | 五月天国产精品 | 国产精品人妻 | 爱如潮水3免费观看日本高清 | 五月婷婷六月综合 | 最新在线中文字幕 | 中文字幕av日韩 | 手机av在线网 | 欧美精品自拍 | 熟妇人妻中文字幕无码老熟妇 | 日本少妇xxxx| 日本香蕉网 | 国产精品久久久久久久久免费相片 | 成人亚洲区 | 久久中文字幕高清 | 少妇av| 亚洲高清毛片一区二区 | 亚洲爆乳无码精品aaa片蜜桃 | 91中出| 国产精品久久久久aaaa | 舐め犯し波多野结衣在线观看 | 亚洲av久久久噜噜噜熟女软件 | 天天干女人 | 蜜臀视频在线观看 | 免费一级毛片麻豆精品 | 国产色网 | 久久亚洲第一 | 97超视频在线观看 | 香蕉视频啪啪 | 偷拍综合网 | 日日干夜夜爽 | 精品久久久亚洲 | 国产精品1区2区3区 在线看黄的网站 | 黑人100部av解禁片 | 三上悠亚久久精品 | 一区二区三区在线免费观看视频 | 男人的天堂2018 | 国产又粗又猛又爽又黄91精品 | 草草地址线路①屁屁影院成人 | 怎么可能高潮了就结束漫画 | 欧美另类日韩 | 色妹av| 99精品视频99 | 在线一区不卡 | 免费三片在线视频 | 亚洲乱码国产乱码精品精软件 | 亚洲经典视频在线观看 | 中文字幕免费在线 | 伊人久久大香线蕉成人综合网 | 97碰| 让男按摩师摸好爽视频 | 男生女生插插插 | 欧美乱仑 | 天天天天干 | 一级片观看| 四虎综合网 | 国产一区二区三区精品愉拍 | 亚洲中文字幕第一区 | 87福利视频 | 女女同性女同一区二区三区按摩 | 国精产品一二三区精华液 | 精品视频一区二区三区 | 天天干夜夜爽 | 美女网站污 | 人人爱爱 | 女生张开腿让男生插 | 日本成片网 | 国产成人精品久久二区二区 | 精品午夜久久 | 精品久久久中文字幕 | 97在线播放免费观看 |