用Python做一个翻译软件
- 2019 年 11 月 13 日
- 筆記
转载自Ahab杂货铺

前两天吃了平哥的一波狗粮,他给女朋友写了一个翻译软件,自己真真切切的感受到了程序员的浪漫。在学习requests请求的时候做过类似的Demo,给百度翻译发送一个post请求可以实现任意词组的翻译,利用周六周日将那段代码进行了进一步优化加了一个交互界面,有了今天的翻译软件。
程序介绍

先上图让大家感受一下
程序的功能很简单,可以从三个主流翻译器中选择任意的翻译器进行单词和句子的翻译,使用PyQt5模块实现人机交互,用requests模块发送请求,并将翻译结果返回给用户。
具体实现
用百度翻译来举例
任意的进行翻译来查看页面信息。

从图片中可以发现这是一个post请求,请求头的数据在的图片中也有较清楚的显示。

我们需要在添加上面的数据,其中simple_means_flag为固定量,query代表待翻译的词,根据这些信息我们写个简单的代码测试一下。
1import requests 2 3headers={"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"} 4post_data={ 5'query': 'Ahab杂货铺', 6'from': 'zh', 7'to': 'en', 8'sign': '413120.175857', 9'token':'64d8ce70799b54833f56b43f9d6eb3b4' 10} 11 12post_url="https://fanyi.baidu.com/v2transapi" 13r=requests.post(post_url,data=post_data,headers=headers) 14print(r.content.decode())
运行以后输出下面的结果:

出现上面错误的原因就是sign和token这两个参数搞的鬼,先说token,token可以直接在百度翻译主页的源码里找到:

因为时间戳不同步所以直接请求百度翻译的主页获取到的token是用不了的,只能人为地把网页当前显示的token值复制下来然后赋值给代码里的token。
sign参数是根据翻译的内容而在前台生成的,如果发送的请求中,query内容和sign不匹配,则收到的响应是error。下面要做的就是破解百度翻译sign。sign是由一个js文件生成的,下图就是生成sign的js文件。

将这个代码放在格式化工具中重新排版一下,找到sign执行函数的代码,再用execjs,执行这段js代码,在计算过程中还需要gtk的值,这个值在翻译首页获取一下就可以。
1js = js.replace(''null !== i ? i : (i = window[l] || "") || ""'',gtk)
上边的步骤完成以后我们就可以愉快的进行翻译了。
关于如何破解sign可以参考这篇博文:https://blog.csdn.net/master_ning/article/details/81002474
图形化界面用的是pyQt5这个模块,实现起来不难。
1class Demo(QWidget): 2 def __init__(self, parent=None): 3 super().__init__() 4 self.setWindowTitle('翻译软件-公众号: Ahab杂货铺') 5 self.Label1 = QLabel('原文') 6 self.Label2 = QLabel('译文') 7 self.LineEdit1 = QLineEdit() 8 self.LineEdit2 = QLineEdit() 9 self.translateButton1 = QPushButton() 10 self.translateButton2 = QPushButton() 11 self.translateButton3 = QPushButton() 12 self.translateButton1.setText('百度翻译') 13 self.translateButton2.setText('有道翻译') 14 self.translateButton3.setText('谷歌翻译') 15 self.grid = QGridLayout() 16 self.grid.setSpacing(12) 17 self.grid.addWidget(self.Label1, 1, 0) 18 self.grid.addWidget(self.LineEdit1, 1, 1) 19 self.grid.addWidget(self.Label2, 2, 0) 20 self.grid.addWidget(self.LineEdit2, 2, 1) 21 self.grid.addWidget(self.translateButton1, 1, 2) 22 self.grid.addWidget(self.translateButton2, 2, 2) 23 self.grid.addWidget(self.translateButton3, 3, 2) 24 self.setLayout(self.grid) 25 self.resize(400, 150) 26 self.translateButton1.clicked.connect(lambda : self.translate(api='baidu')) 27 self.translateButton2.clicked.connect(lambda : self.translate(api='youdao')) 28 self.translateButton3.clicked.connect(lambda : self.translate(api='google')) 29 self.bd_translate = baidu() 30 self.yd_translate = youdao() 31 self.gg_translate = google() 32 def translate(self, api='baidu'): 33 word = self.LineEdit1.text() 34 if not word: 35 return 36 if api == 'baidu': 37 results = self.bd_translate.translate(word) 38 elif api == 'youdao': 39 results = self.yd_translate.translate(word) 40 elif api == 'google': 41 results = self.gg_translate.translate(word) 42 else: 43 raise RuntimeError('Api should be <baidu> or <youdao> or <google>...') 44 for result in results: 45 self.LineEdit2.setText(result)
pyQt5官方文档:https://pypi.org/project/PyQt5/
最后就是打包发布,使用pyinstaller傻瓜式操作即可完成。程序虽小五脏俱全,技术难点还是在爬虫那块的处理。希望这个小程序能给你带来一点帮助。
写在最后
代码已经上传到Github点击阅读原文即可浏览。
为您推荐
吴恩达 deeplearning.ai 经典总结:28 张精炼图+思维导图(附下载链接)