利用爬虫,和界面模块实现了自己写的翻译器(其实是调用了有道翻译的)

利用爬虫,和界面模块实现了自己写的翻译器(其实是调用了有道翻译的)

-- coding: UTF-8 --

from urllib import request
from urllib import parse
import json
from tkinter import *

def translate():
w = var.get()
i = w
# 对应上图的Request URL
Request_URL = ‘http://fanyi.youdao.com/translate’
# 创建Form_Data字典,存储上图的Form Data
Form_Data = {}
Form_Data[‘i’] = i
Form_Data[‘from’] = ‘AUTO’
Form_Data[‘to’] = ‘AUTO’
Form_Data[‘smartresult’] = ‘dict’
Form_Data[‘client’] = ‘fanyideskweb’
Form_Data[‘salt’] = ‘1535203647951’
Form_Data[‘sign’] = ‘6638766e48bdd9b5a4af84d9c8414995’
Form_Data[‘doctype’] = ‘json’
Form_Data[‘version’] = ‘2.1’
Form_Data[‘action’] = ‘FY_BY_CLICKBUTTION’
Form_Data[‘typoResult’] = ‘fanyi.web’
Form_Data[‘keyfrom’] = ‘false’
# 使用urlencode方法转换标准格式
data = parse.urlencode(Form_Data).encode(‘utf-8’)
# 传递Request对象和转换完格式的数据
response = request.urlopen(Request_URL, data)
# 读取信息并解码
html = response.read().decode(‘utf-8’)
# 使用JSON
translate_results = json.loads(html)
# 找到翻译结果
translate_results = translate_results[‘translateResult’][0][0][‘tgt’]
# 打印翻译信息
t.delete(1.0, END)
t.insert(END, translate_results)
t.insert(END, ‘\n’)
print(“翻译的结果是:%s” % translate_results)

if name == “main“:
while(True):
root = Tk()
root.title(“翻译器”) # 标题
root.geometry(‘400x500’) # 是x 不是* 界面大侠
root.resizable(width=False, height=True) # 宽不可变, 高可变,默认为True
var = StringVar()
e = Entry(root, textvariable=var)
e.pack()
t = Text()
t.pack()
Button(root, text=”press”, command=translate).pack()
root.mainloop() # 循环显示

利用爬虫,和界面模块实现了自己写的翻译器(其实是调用了有道翻译的)_第1张图片

你可能感兴趣的:(利用爬虫,和界面模块实现了自己写的翻译器(其实是调用了有道翻译的))