简易英语词典
本帖最后由 suchocolate 于 2020-2-8 19:10 编辑利用request,tkinter等技术制作的简易英文字典:
https://xxx.ilovefishc.com/album/202002/08/182321w0qkw9aeooznw8ha.pnghttps://xxx.ilovefishc.com/album/202002/08/182315mowiltufjzi5ozuu.pngimport requests
from lxml import etree
from tkinter import *
from urllib.parse import quote
# 英文查询
ebase = 'http://dict.youdao.com/w/eng/'
# 中文查询
cbase = 'http://dict.youdao.com/w/'
# 查询时http头
headers = {"User-Agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:72.0) Gecko/20100101 Firefox/72.0"}
# 查询函数
def chaxun():
# 获取输入框内容
wd = e1.get()
# 分析输入框内容
if '\u4e00' <= wd <= '\u9fff':
# 如果是中文查询,转换中文为URL编码格式
wd = quote(wd)
url = cbase + wd
r = requests.get(url, headers=headers)
html = etree.HTML(r.text)
# 获取查询结果
result = html.xpath('/html/body/div/div/div/div/div/div/div/ul/p/span/a/text()')
else:
url = ebase + wd
r = requests.get(url, headers=headers)
html = etree.HTML(r.text)
result = html.xpath('/html/body/div/div/div/div/div/div/div/ul/li/text()')
# 清理text,重新显示
text1.delete(1.0, END)
# 如果有结果,显示结果
if len(result) != 0:
for pt in result:
text1.insert(INSERT, pt + '\n')
else:
# 如果没有结果,提示没有结果
text1.insert(INSERT, 'There is no explain.')
if __name__ == '__main__':
# 主函数,定义一个tk对象,设置标题
root = Tk()
root.title('简易有道字典')
# 文字提示
l1 = Label(root, text='请输入要查询的单词:')
l1.grid(row=0)
# 添加一个输入框
e1 = Entry(root)
e1.grid(row=0, column=1, padx=10, pady=5)
# 添加一个按钮,点击时执行查询程序
bt1 = Button(root, text='查询', command=chaxun)
bt1.grid(row=0, column=2, padx=10, pady=5)
# 定义一个文本框,展示查询结果
text1 = Text(root, width=45, height=10)
text1.grid(row=1, columnspan=3)
# 主窗体循环
mainloop()
不错不错{:10_275:} 本帖最后由 suchocolate 于 2020-2-8 21:37 编辑
进阶带翻译版
from urllib import request, parse
from urllib.parse import quote
from lxml import etree
from tkinter import *
import json
# 英文单词查询网址
ebase = 'http://dict.youdao.com/w/eng/'
# 中文单词查询网址
cbase = 'http://dict.youdao.com/w/'
# 翻译网址
trans = 'http://fanyi.youdao.com/translate?smartresult=dict&smartresult=rule'
# 查询时http头
headers = {"User-Agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:72.0) Gecko/20100101 Firefox/72.0"}
# 翻译提交的字典
dic = {"doctype": "json"}
# 判断查询类型
def chaxun():
if v.get() == 1:
chaci()
else:
fanyi()
# 查词 chaci():
def chaci():
wd = e1.get()
if '\u4e00' <= wd <= '\u9fff':
# 如果是中文查询,转换中文为URL编码格式
wd = quote(wd)
url = cbase + wd
q = request.Request(url=url, headers=headers)
r = request.urlopen(q, timeout=2)
html = etree.HTML(r.read().decode('utf-8'))
result = html.xpath('/html/body/div/div/div/div/div/div/div/ul/p/span/a/text()')
else:
url = ebase + wd
q = request.Request(url=url, headers=headers)
r = request.urlopen(q, timeout=2)
html = etree.HTML(r.read().decode('utf-8'))
result = html.xpath('/html/body/div/div/div/div/div/div/div/ul/li/text()')
# 清理text,重新显示
text1.delete(1.0, END)
# 如果有结果,显示结果
if len(result) != 0:
for pt in result:
text1.insert(INSERT, pt + '\n')
else:
# 如果没有结果,提示没有结果
text1.insert(INSERT, 'There is no explain.')
# 翻译
def fanyi():
text1.delete(1.0, END)
wd = e1.get()
dic['i'] = wd
data = bytes(parse.urlencode(dic), encoding='utf-8')
q = request.Request(url=trans, data=data, headers=headers, method='POST')
r = request.urlopen(q)
result = json.loads(r.read().decode('utf-8'))
text1.insert(INSERT, result['translateResult']['tgt'])
if __name__ == '__main__':
# 主函数,定义一个tk对象
root = Tk()
root.title('简易有道字典')
l1 = Label(root, text='请输入要查询的内容:')
l1.grid(row=0, column=0)
e1 = Entry(root)
e1.grid(row=0, column=1, padx=1, pady=5)
bt1 = Button(root, text='查询', command=chaxun)
bt1.grid(row=0, column=2, padx=5, pady=5)
text1 = Text(root, width=59, height=10)
text1.grid(row=1, columnspan=5, padx=5, pady=7)
v = IntVar()
v.set(1)
Radiobutton(root, text="查词", variable=v, value=1).grid(row=0, column=3)
Radiobutton(root, text="翻译", variable=v, value=2).grid(row=0, column=4)
mainloop()
在python3.864-bit里跑,lxml要改成xml 本帖最后由 suchocolate 于 2020-3-21 20:24 编辑
Nelson盟新 发表于 2020-3-21 14:53
在python3.864-bit里跑,lxml要改成xml
https://xxx.ilovefishc.com/album/202003/21/201545jk3ksp5z8hyaj3yy.png
我这里python 3.8.2 64位,没有要求改。
另外我查了下lxml官网api手册,没说改名,还是这个方式导入:https://lxml.de/api.html
https://xxx.ilovefishc.com/album/202003/21/202249eeff3hbhymmsfe7p.png
本帖最后由 Nelson盟新 于 2020-3-21 22:55 编辑
用这个查的
https://github.com/python/cpython/tree/3.8/Lib/
XML tree and elements
XML is an inherently hierarchical data format, and the most natural way to represent it is with a tree. ET has two classes for this purpose - ElementTree represents the whole XML document as a tree, and Element represents a single node in this tree. Interactions with the whole document (reading and writing to/from files) are usually done on the ElementTree level. Interactions with a single XML element and its sub-elements are done on the Element level.
我只能用这个库才能跑起来
from xml import etree
Nelson盟新 发表于 2020-3-21 22:49
用这个查的
https://github.com/python/cpython/tree/3.8/Lib/
查了一下,xml是python自带的库。
我用的lxml是第三方库,需要单独安装。
页:
[1]