本篇文章主要講講述了用Python實現翻譯軟體,超級實用,趕緊將程式碼收藏起來試試吧,希望對你學習Python有所啟發哦!
前兩天吃了平哥的一波狗糧,他給女朋友寫了一個翻譯軟體,自己真真切切的感受到了程式設計師的浪漫。在學習requests請求的時候做過類似的Demo,給百度翻譯發送一個post請求可以實現任意詞組的翻譯,利用周六週日將那段代碼進行了進一步優化加了一個交互界面,有了今天的翻譯軟體.
#先上圖讓大家感受一下
#程式的功能很簡單,可以從三個主流翻譯器中選擇任意的翻譯器進行單字和句子的翻譯,使用PyQt5 模組實現人機交互,用requests模組發送請求,並將翻譯結果傳回給使用者。
#用百度翻譯來舉例
任意的進行翻譯來查看頁面資訊。
#從圖片中可以發現這是一個post請求,請求頭的資料在的圖片中也有較清楚的顯示。
我們需要在添加上面的數據,其中simple_means_flag 為固定量,query 代表待翻譯的詞,根據這些資訊我們寫個簡單的程式碼測試一下。
import requests headers={"User-Agent": "Mozilla/5.0 (Windows NT 6.1; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/71.0.3578.80 Safari/537.36"} post_data={ 'query': 'Ahab杂货铺', 'from': 'zh', 'to': 'en', 'sign': '413120.175857', 'token':'64d8ce70799b54833f56b43f9d6eb3b4' } post_url="https://fanyi.baidu.com/v2transapi" r=requests.post(post_url,data=post_data,headers=headers) print(r.content.decode())
運行以後輸出下面的結果:
#出現上面錯誤的原因是sign和token這兩個參數搞的鬼,先說token,token可以直接在百度翻譯主頁的源碼裡找到:
#因為時間戳不同步所以直接請求百度翻譯的主頁獲取到的token 是用不了的,只能人為地把網頁目前顯示的token 值複製下來然後賦值給程式碼裡的token。
sign 參數是根據翻譯的內容而在前台產生的,如果發送的請求中,query 內容和 sign 不匹配,則收到的回應是 error。下面要做的就是破解百度翻譯 sign。 sign 是由一個 js 檔案產生的,下圖就是產生 sign 的 js 檔案。
#将这个代码放在格式化工具中重新排版一下,找到 sign 执行函数的代码,再用 execjs,执行这段 js 代码,在计算过程中还需要 gtk 的值,这个值在翻译首页获取一下就可以。
js = js.replace(
上边的步骤完成以后我们就可以愉快的进行翻译了。
图形化界面用的是 pyQt5 这个模块,实现起来不难。
class Demo(QWidget): def __init__(self, parent=None): super().__init__() elf.setWindowTitle('翻译软件-公众号: Ahab杂货铺') self.Label1 = QLabel('原文') self.Label2 = QLabel('译文') self.LineEdit1 = QLineEdit() self.LineEdit2 = QLineEdit() self.translateButton1 = QPushButton() self.translateButton2 = QPushButton() self.translateButton3 = QPushButton() self.translateButton1.setText('百度翻译') self.translateButton2.setText('有道翻译') self.translateButton3.setText('谷歌翻译') self.grid = QGridLayout() self.grid.setSpacing(12) self.grid.addWidget(self.Label1, 1, 0) self.grid.addWidget(self.LineEdit1, 1, 1) self.grid.addWidget(self.Label2, 2, 0) self.grid.addWidget(self.LineEdit2, 2, 1) self.grid.addWidget(self.translateButton1, 1, 2) self.grid.addWidget(self.translateButton2, 2, 2) self.grid.addWidget(self.translateButton3, 3, 2) self.setLayout(self.grid) self.resize(400, 150) self.translateButton1.clicked.connect(lambda : self.translate(api='baidu')) self.translateButton2.clicked.connect(lambda : self.translate(api='youdao')) self.translateButton3.clicked.connect(lambda : self.translate(api='google')) self.bd_translate = baidu() elf.yd_translate = youdao() self.gg_translate = google() def translate(self, api='baidu'): word = self.LineEdit1.text() if not word: return if api == 'baidu': results = self.bd_translate.translate(word) elif api == 'youdao': results = self.yd_translate.translate(word) elif api == 'google': results = self.gg_translate.translate(word) else: raise RuntimeError('Api should be <baidu> or <youdao> or <google>...') for result in results: self.LineEdit2.setText(result)</google></youdao></baidu>
相关教程:Python视频教程
以上是Python實作翻譯軟體的詳細內容。更多資訊請關注PHP中文網其他相關文章!