基于Python的有道翻译小软件

Dreamlover

发布日期: 2019-05-02 20:41:30 浏览量: 561
评分:
star star star star star star star star star star_border
*转载请注明来自write-bug.com
  • Python 2.7.13

  • IDE Pycharm 5.0.3

  • macOS 10.12.1

前言

花了一点时间,半抄半写半修改的写了第一个能用的python小程序,作用是在IDE端模拟有道词典的访问,效果如下图所示,不足之处在于,当输入的中英文字符串超过一定数量,会抛出中间代码,新手并不知道怎么处理,望知道的不吝赐教

初阶:交互界面

首先在jupyter或者pycharm中进行交互的操作,核心语句是使用raw_input捕获系统输入

1. 效果图

2. 代码

  1. # -*- coding: utf-8 -*-
  2. import urllib2
  3. import urllib # python2.7才需要两个urllib
  4. import json
  5. while True:
  6. content = raw_input("请输入需要翻译的内容:") # 系统捕获输入,就是命令框会弹出提示,需要你进行手动输入
  7. if content == 'q': # 输入q退出while循环
  8. break
  9. url = "http://fanyi.youdao.com/translate?smartresult=dict&smartresult=rule&smartresult=ugc&sessionFrom=null"
  10. data = {} # 构造data,里面构造参数传入
  11. data['type'] = 'AUTO'
  12. data['i']=content
  13. data['doctype'] = 'json'
  14. data['xmlVersion'] = '1.8'
  15. data['keyfrom'] = 'fanyi.web'
  16. data['ue'] = 'UTF-8'
  17. data['action'] = 'FY_BY_ENTER'
  18. data['typoResult'] = 'true'
  19. data = urllib.urlencode(data).encode('utf-8') # 将构造的data编码
  20. req = urllib2.Request(url) # 向浏览器发出请求
  21. response = urllib2.urlopen(req, data) # 带参请求,返回执行结果
  22. html = response.read().decode('utf-8')
  23. # print(html) # 可以取消print的注释,查看其中效果,这边获取的结果是进行解析
  24. target = json.loads(html) # 以json形式载入获取到的html字符串
  25. print "翻译的内容是:"+target['translateResult'][0][0]['tgt'].encode('utf-8')
  26. # 请输入需要翻译的内容:test
  27. # 翻译的内容是:测试
  28. # 请输入需要翻译的内容:测试
  29. # 翻译的内容是:test
  30. # 请输入需要翻译的内容:q

注意:这里的data字典中的数据根据实际网页中数据为准,可能会不一样,具体操作,点击审查元素。

进阶:做成gui

离实用还差那么两步,第一步是先做成GUI

1. 界面效果

2. 代码

  1. # -*- coding: utf-8 -*-
  2. from Tkinter import *
  3. import difflib
  4. import urllib2
  5. import urllib # python2.7才需要两个urllib
  6. import json
  7. # ----------------------主框架部分----------------------
  8. root = Tk()
  9. root.title('翻译GUI&beta1')
  10. root.geometry()
  11. Label_root=Label(root)
  12. #-----------------------定义规则------------------------
  13. def translate(content):
  14. url = "http://fanyi.youdao.com/translate?smartresult=dict&smartresult=rule&smartresult=ugc&sessionFrom=null"
  15. data = {} # 构造data,里面构造参数传入
  16. data['type'] = 'AUTO'
  17. data['i']=content
  18. data['doctype'] = 'json'
  19. data['xmlVersion'] = '1.8'
  20. data['keyfrom'] = 'fanyi.web'
  21. data['ue'] = 'UTF-8'
  22. data['action'] = 'FY_BY_ENTER'
  23. data['typoResult'] = 'true'
  24. data = urllib.urlencode(data).encode('utf-8') # 将构造的data编码
  25. req = urllib2.Request(url) # 向浏览器发出请求
  26. response = urllib2.urlopen(req, data) # 带参请求,返回执行结果
  27. html = response.read().decode('utf-8')
  28. # print(html) # 可以取消print的注释,查看其中效果,这边获取的结果是进行解析
  29. target = json.loads(html) # 以json形式载入获取到的html字符串
  30. #print u"翻译的内容是:"+target['translateResult'][0][0]['tgt']
  31. return target['translateResult'][0][0]['tgt'].encode('utf-8')
  32. #还可以继续增加规则函数,只要是两输入的参数都可以
  33. #----------------------触发函数-----------------------
  34. def Answ():# 规则函数
  35. Ans.insert(END,"翻译 %s: "%var_first.get().encode('utf-8') + translate(var_first.get().encode('utf-8')))
  36. def Clea():#清空函数
  37. input_num_first.delete(0,END)#这里entrydelect0
  38. Ans.delete(0,END)#text中的用0.0
  39. #----------------------输入选择框架--------------------
  40. frame_input = Frame(root)
  41. Label_input=Label(frame_input, text='请输入需要翻译的内容', font=('',15))
  42. var_first = StringVar()
  43. input_num_first = Entry(frame_input, textvariable=var_first)
  44. #---------------------计算结果框架---------------------
  45. frame_output = Frame(root)
  46. Label_output=Label(frame_output, font=('',15))
  47. Ans = Listbox(frame_output, height=5,width=30) #text也可以,Listbox好处在于换行
  48. #-----------------------Button-----------------------
  49. calc = Button(frame_output,text='翻译', command=Answ)
  50. cle = Button(frame_output,text='清空', command=Clea)
  51. Label_root.pack(side=TOP)
  52. frame_input.pack(side=TOP)
  53. Label_input.pack(side=LEFT)
  54. input_num_first.pack(side=LEFT)
  55. frame_output.pack(side=TOP)
  56. Label_output.pack(side=LEFT)
  57. calc.pack(side=LEFT)
  58. cle.pack(side=LEFT)
  59. Ans.pack(side=LEFT)
  60. #-------------------root.mainloop()------------------
  61. root.mainloop()

高阶:发布应用

如何在小伙伴面前装B才是我学习的动力,哈哈哈

Pay Attention

  • python3的用户注意url包的使用和python2是有区别的,请根据实际需求自行百度

  • Python如果操作频率太快或者网页限制机器人对此的访问,则需要修改head了,修改代码后.当然每个电脑的user都不一样,具体去审查元素查看。

  1. req = urllib2.Request(url) # 生成对象
  2. # 添加如下一行代码;
  3. req.add_header('User-Agent','Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/45.0.2454.101 Safari/537.36'),这样就可以伪装成人类啦
  • 当然也可以添加延时模块, 即可限定访问时间。
  1. import time #添加延时模块
  2. time.sleep(1)#休息1秒钟再进行操作
上传的附件 cloud_download 基于Python的有道翻译小软件.zip ( 346.04kb, 12次下载 )
error_outline 下载需要9点积分

发送私信

花有重开日,人无再少年

17
文章数
21
评论数
最近文章
eject