前面我们对图形界面进行了设计并通过爬虫完成了翻译功能,这一节我们就把前面的内容结合到一起完成翻译器的制作。
1. 完整代码
import wx import urllib.request # 导入模块 import urllib.parse import json class MyFrame(wx.Frame): def __init__(self): wx.Frame.__init__(self, None, -1, "翻译器", size=(600, 200)) panel = wx.Panel(self)#创建一个画布,然后创建功能区并放到画布上 #创建一个标题,放在panel中 self.title = wx.StaticText(panel,label = '简单翻译器') #创建一个静态文本,放在panel中 self.translate = wx.StaticText(panel,label = '翻译内容:') #创建一个输入文本框,放在panel中 self.tran_slate = wx.TextCtrl(panel,style = wx.TE_LEFT) #创建一个翻译按钮,放在panel中 self.button_ts = wx.Button(panel,label = '翻译') #绑定按钮事件,点击触发翻译函数 self.button_ts.Bind(wx.EVT_BUTTON, self.OnclickEventname) #创建一个关闭按钮,放在panel中 self.button_shutdown = wx.Button(panel, label='关闭') #绑定按钮事件,点击触发关闭函数 self.button_shutdown.Bind(wx.EVT_BUTTON, self.OnclickEvent) container_one = wx.BoxSizer(wx.HORIZONTAL) #把静态文本和输入文本框放在这个BoxSizer当中 container_one.Add(self.translate,proportion = 0,flag = wx.ALL,border = 7) container_one.Add(self.tran_slate,proportion = 1,flag = wx.ALL,border = 7) #再创建一个水平排布的BoxSizer container_two = wx.BoxSizer(wx.HORIZONTAL) #把两个按钮放到这个BoxSizer中 container_two.Add(self.button_ts,proportion = 0,flag = wx.ALIGN_CENTER,border = 4) container_two.Add(self.button_shutdown,proportion =0,flag = wx.ALIGN_CENTER,border = 4) #创建一个竖直排布的BoxSizer sizers = wx.BoxSizer(wx.VERTICAL) #把上面的内容都放到这个BoxSizer当中即可 sizers.Add(self.title,proportion=0,flag=wx.BOTTOM|wx.TOP|wx.ALIGN_CENTER,border=10) sizers.Add(container_one,proportion = 0,flag =wx.EXPAND|wx.LEFT|wx.RIGHT,border=40) sizers.Add(container_two, proportion=0, flag=wx.ALIGN_CENTER|wx.TOP, border=10) panel.SetSizer(sizers) def OnclickEventname(self,e): global panel urnm = self.tran_slate.GetValue() url = "http://fanyi.youdao.com/translate?smartresult=dict&smartresult=rule" data = {} data['i'] = urnm data['from'] = 'AUTO' data['to'] = 'AUTO' data['smartresult'] = 'dict' data['client'] = 'fanyideskweb' data['salt'] = '15823411455528' data['sign'] = 'd03024a90896a5eb31a74a9344657b0e' data['doctype'] = 'json' data['version'] = '2.1' data['keyfrom'] = 'fanyi.web' data['action'] = 'FY_BY_REALTlME' data = urllib.parse.urlencode(data).encode('utf-8') r = urllib.request.Request(url, data) r.add_header('User-Agent', 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/79.0.3945. 130 Safari/537.36') response = urllib.request.urlopen(r) html = response.read().decode('utf-8') trs = json.loads(html) result = trs['translateResult'][0][0]['tgt'] print("翻译结果:",result) wx.MessageBox('翻译结果:%s'%result,'翻译器') def OnclickEvent(self,e): self.Destroy() if __name__ == "__main__": app = wx.App() frame = MyFrame() frame.Show() app.MainLoop()
2. 代码分析
由于本节的代码是源于前两节,相同的代码部分我们就不再重复去分析,我们主要来看一下不同的地方,
#创建一个翻译按钮,放在panel中 self.button_ts = wx.Button(panel,label = '翻译') #绑定按钮事件,点击触发翻译函数 self.button_ts.Bind(wx.EVT_BUTTON, self.OnclickEventname) #创建一个关闭按钮,放在panel中 self.button_shutdown = wx.Button(panel, label='关闭') #绑定按钮事件,点击触发关闭函数 self.button_shutdown.Bind(wx.EVT_BUTTON, self.OnclickEvent)
我们在翻译和关闭按钮上面分别绑定了事件,在点击的时候会触发相应的函数,来分析一下函数,关闭按钮的函数相对比较简单,即点击按钮关闭窗口。
def OnclickEvent(self,e): self.Destroy()
在我们点击翻译按钮的时候会触发翻译功能,翻译功能中内容大家在上一节中可以详细的了解到,这里我们主要进行一个参数的传递。
urnm = self.tran_slate.GetValue()
把GUI界面输入的信息传递到data当中。
data['i'] = urnm
这样就对应了上一节我们输入的content内容,最后再看这一行代码
wx.MessageBox('翻译结果:%s'%result,'翻译器')
我们通过一个窗口来返回翻译结果,这样就实现了翻译功能。
3. 测试
最后我们来测试我们的翻译器。
4. 总结
本节的实战内容较为基础,主要是结合GUI编程和爬虫的内容,如果感兴趣的还可以结合数据库进行更加完整的实战内容,下一个实战会结合数据库来进一步完成实战内容。
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程