飞道的博客

我要偷偷的学Python,然后惊呆所有人(第十四天)

593人阅读  评论(0)

标题无意冒犯,就是觉得这个广告挺好玩的
上面这张思维导图喜欢就拿走,反正我也学不了这么多

前言

前期回顾:我要偷偷学Python(第十三天)

又一篇爆款啊。

插播一条推送:(如果是小白的话,可以看一下下面这一段)

欢迎来到我们的圈子

我建了一个Python学习答疑群,有兴趣的朋友可以了解一下:这是个什么群

群里已经有一千多个小伙伴了哦!!!

直通群的传送门:传送门


本系列文默认各位有一定的C或C++基础,因为我是学了点C++的皮毛之后入手的Python,这里也要感谢齐锋学长送来的支持。
本系列文默认各位会百度,学习‘模块’这个模块的话,还是建议大家有自己的编辑器和编译器的,上一篇已经给大家做了推荐啦?

我要的不多,点个关注就好啦
然后呢,本系列的目录嘛,说实话我个人比较倾向于那两本 Primer Plus,所以就跟着它们的目录结构吧。

本系列也会着重培养各位的自主动手能力,毕竟我不可能把所有知识点都给你讲到,所以自己解决需求的能力就尤为重要,所以我在文中埋得坑请不要把它们看成坑,那是我留给你们的锻炼机会,请各显神通,自行解决。

摊牌啦,《偷偷学Python》系列即将进入一段漫长的XXX

漫长的《爬虫百战》时期啦。

对,接下来会放出大量的小项目实操,有些会带上经济效益,有些纯粹练着好玩。

当然,写着好玩的小项目肯定不会全写完,但是我会做成一个高可拓展的项目,把接口明确了,大家有意愿的话就自行拓展。

《Python百战穿山甲》(一):翻译软件

为什么我会想做这个呢?好玩呗,我关注了几个“爬虫百战”的专栏,先挑了这个来做,不过他们大多是只能翻译一个单词的,那我也会啊,没意思。

在我的不懈努力之下,我爬呀爬,爬呀爬,终于爬到了一个大佬,他把人家的加密算法给破解了。

事情是这样的:为什么大部分的博客都只提供单个单词的翻译呢?因为他们没办法提供多个单词翻译,而且他们能抓到的单词释义也是有限的,算了,还是放图吧,感觉不放图讲不清楚了今天:

呐,他们都是用这个叫做sug的不完全包,我刚开始在百度翻译上确实也能抓出这样的包,但是在有道上刷不出来。

其实是应该用这张图里面的第一个的那种包,但是那个包有加密,在百度翻译上面,你要带上cookie,还有两个秘钥,暂且算是秘钥,因为这些东西都是跟随单词而变化的,所以如果每个都是抓包,拆包,那其实没什么意义了。

这时候,有个大佬发现了其中的规律,于是他用一顿猛如虎的操作,呐:https://blog.csdn.net/nunchakushuang/article/details/75294947

好极,破解了。

然后就有了我们后面的操作。

以下这段代码是我们群里的小伙伴肆柒和我一起协作完成的,我把改好的算法给他,他配备上了UI。

import urllib.request
import requests
import urllib.parse
import json
import time
import random
import hashlib
import tkinter
from tkinter import ttk

text = ""

# 清空输入框
def qing_kong(shu_ru):
    shu_ru.delete(0, tkinter.END)

# 确定开始查询
def que_ding(a, b, content, shu_chu):
    global text
    # content = input('请输入需要翻译的内容:')
    # from_s = input("请输入待翻译的语种,中文请输入ZH,英文请输入EN:")
    # to_s = input("请输入目标语种,中文请输入ZH,英文请输入EN:")
    if a == "汉语":
        from_s = 'ZH'
    else:
        from_s = 'EN'
    if a == "英语":
        to_s = 'EN'
    else:
        to_s = 'ZH'

    # url = 'http://fanyi.youdao.com/translate?smartresult=dict&smartresult=rule&sessionFrom=https://www.google.com/'
    url = 'http://fanyi.youdao.com/translate?smartresult=dict&smartresult=rule'
    data = {
   }

    u = 'fanyideskweb'
    d = content
    f = str(int(time.time() * 1000) + random.randint(1, 10))
    c = 'rY0D^0\'nM0}g5Mm1z%1G4'

    sign = hashlib.md5((u + d + f + c).encode('utf-8')).hexdigest()

    data['i'] = content
    data['from'] = from_s
    data['to'] = to_s
    data['smartresult'] = 'dict'
    data['client'] = 'fanyideskweb'
    data['salt'] = f
    data['sign'] = sign
    data['doctype'] = 'json'
    data['version'] = '2.1'
    data['keyfrom'] = 'fanyi.web'
    data['action'] = 'FY_BY_CL1CKBUTTON'
    data['typoResult'] = 'true'

    data = urllib.parse.urlencode(data).encode('utf-8')

    res = requests.post(url, data=data)
    request = urllib.request.Request(url=url, data=data, method='POST')
    response = urllib.request.urlopen(request)

    # print(response.read().decode('utf-8'))
    pre_js = response.read().decode('utf-8')

    # pat=re.compile(r'[\u4e00-\u9fa5]+')
    # result=pat.findall(pre_js)
    # result = '\n'.join(result[5:])

    a = pre_js.split('[[')
    b = a[1].split(']]')
    c = b[0]

    j = json.loads(c)
    text = j['tgt']
    shu_chu.set(text)
    print(j['tgt'])
    # for i in result:
    #    print(i+'\n')
    # print(pre_js)


# 主函数
def jie_main():
    global text
    win = tkinter.Tk()
    win.title("翻译")
    win.geometry("500x400")
    win.resizable(0, 0)

    shu_chu = tkinter.StringVar()
    shu_chu.set(text)

    tkinter.Label(win, text='翻译', font=('Arial', 12)).place(x=100, y=30, anchor='nw')

    tkinter.Label(win, text='翻译语言选项', font=('Arial', 12)).place(x=10, y=70, anchor='nw')
    yu_yan1 = ttk.Combobox(win, width=10)
    yu_yan1['value'] = ('汉语', '英语')
    yu_yan1.current(0)
    yu_yan1.place(x=120, y=70, anchor='nw')
    tkinter.Label(win, text='》》》', font=('Arial', 12)).place(x=220, y=70, anchor='nw')
    yu_yan2 = ttk.Combobox(win, width=10)
    yu_yan2['value'] = ('英语', '汉语')
    yu_yan2.current(0)
    yu_yan2.place(x=270, y=70, anchor='nw')

    tx1 = tkinter.Label(win, text='原文:', font=('Arial', 12))
    tx1.place(x=10, y=120, anchor='nw')
    shu_ru = tkinter.Entry(win)
    shu_ru.place(x=120, y=120, anchor='nw')
    guess = shu_ru.get()

    tx2 = tkinter.Label(win, text='译文:', font=('Arial', 12))
    tx2.place(x=10, y=160, anchor='nw')
    tkinter.Label(win, textvariable=shu_chu, font=('Arial', 12)).place(x=100, y=160, anchor='nw')

    bt1 = tkinter.Button(win, text='清空', command=lambda: qing_kong(shu_ru))
    bt1.place(x=10, y=210, anchor='nw')
    bt2 = tkinter.Button(win, text='确定', command=lambda: que_ding(yu_yan1.get(), yu_yan2.get(), shu_ru.get(), shu_chu))
    bt2.place(x=100, y=210, anchor='nw')

    win.mainloop()


if __name__ == '__main__':
    jie_main()

设计图

感觉好像也没什么可拓展的了嘛,除了那个语言模块那边。
应该是我们的小伙伴做的太完善了已经。

我来说一下我的想法啊,长话短说吧,再不说完等下来不及审核了。

建造者模式。

场景类从语种类中获取所有的语种类别,然后填充到UI类的下拉框中,场景类开放,算法和UI封闭。

草率了点,UML都没开。。。
见谅啊。

如果大家有任何疑惑,可以直接问我,也可以了解一下什么是建造者模式


转载:https://blog.csdn.net/qq_43762191/article/details/109824836
查看评论
* 以上用户言论只代表其个人观点,不代表本网站的观点或立场