suchocolate 发表于 2020-2-8 18:21:00

简易英语词典

本帖最后由 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()

zltzlt 发表于 2020-2-8 18:42:08

不错不错{:10_275:}

suchocolate 发表于 2020-2-8 21:35:52

本帖最后由 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()

Nelson盟新 发表于 2020-3-21 14:53:59

在python3.864-bit里跑,lxml要改成xml

suchocolate 发表于 2020-3-21 20:17:58

本帖最后由 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:49:49

本帖最后由 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






suchocolate 发表于 2020-3-22 08:30:49

Nelson盟新 发表于 2020-3-21 22:49
用这个查的
https://github.com/python/cpython/tree/3.8/Lib/



查了一下,xml是python自带的库。
我用的lxml是第三方库,需要单独安装。
页: [1]
查看完整版本: 简易英语词典