python实现查有道词典

真匿名打脸爱好者 2017-10-05

因为要考英语四级,所以我今天一大早就起来被英语单词,但是作为英语渣渣的我,只能是在网页上挨个查单词的意思。查的多了,心生厌倦,便想着如何才能在终端下查单词,那样速度不就很快了?

NOW,我仔细观察每次查询时,浏览器地址栏中URL的变化,发现每次浏览器提交的URL都是"http://www.youdao.com/w/eng/"xxxxx"/#keyfrom=dict2.index"(其中的xxxxx代表要查的单词),有了这个发现,那我们将URL指向的网页下载下来,然后提取我们需要的信息不就得了?

emmmm,这个工作交给Python来做是最合适不过的了

基本步骤:导入requests模块与re模块,首先将URL地址指向的网页下载下来,然后利用Python强大的正则表达式提取单词经过翻译后的信息。因为要英汉互译,所以我写了两段代码,第一个是汉译英,第二个是英译汉。

源代码

汉译英:

import requests,re<br /><br />def download():
    word=input("请输入您要翻译的中文词语:\n")
    url="http://dict.youdao.com/w/eng/"+word+"/#keyfrom=dict2.index"   #合并URL地址
    html=requests.get(url).content.decode('utf-8')    #得到服务器的相应信息后将其转码为UTF-8
    return html

def analysis():   
    list1=re.findall("详细释义.+<p class=\"collapse-content\">",download(),re.S)   #这里对html字符串进行第一步加工,截取大概的信息
    list2=re.findall("                [a-zA-Z ]+",str(list1))      #将上面加工后的字符串进一步加工,直接提取到所有翻译后的单词信息
    print("翻译结果:\n")
    for i in list2:
        i=i.strip()   #因为第二步加工后的信息并不干净,得到的单词前面会有空格,这里将空格删去
        print(i)
if __name__ == '__main__':
  while(1):<br />    analysis()

英译汉:

import requests,re

def download():
    word=input("请输入您要翻译的英文单词:\n")
    url="http://dict.youdao.com/w/eng/"+word+"/#keyfrom=dict2.index"
    html=requests.get(url).content.decode('utf-8')
    return html

def analysis():
    list1=re.findall("详细释义.+<p class=\"collapse-content\">",download(),re.S)
    list2=re.findall("                \w+",str(list1))       #只有此处代码与汉译英代码不同,因为是提取汉字,所以这里要用\w来匹配汉字
    print("翻译结果:\n")
    for i in list2:
        i=i.strip()
        print(i)

if __name__ == '__main__':<br />  while(1):<br />    analysis()

OK,来看看效果吧:

python实现查有道词典python实现查有道词典

emmmm,OK,发完博客还要继续背单词【伤心】【伤心】【伤心】

相关推荐