既然如此,那我们就找form data吧,看看要提交什么数据上去:
判断一下,这个 i 就是待查询的数据,from 是 i 的语言,to 是目标语言,默认是英语。至于有道上有多少中语种支持,它们的代号分别是什么,自行想办法。(不要设自动检测就行。)
剩下那些,salt时间戳,我讲过的,上面推荐的那个专栏里面也会有。
sign,md5的码,事实证明要不要自己写都行,大不了就直接去复制一个。
时间戳也是。无所谓的。
讲解到此,上代码:
import urllib.request
import requests
import urllib.parse
import json
import time # 做时间戳的
import random # 为做时间戳提供随机值
import hashlib # md5所用
content = input(‘请输入需要翻译的内容:’)
from_s = input(“请输入待翻译的语种,中文请输入ZH,英文请输入EN:”)
to_s = input(“请输入目标语种,中文请输入ZH,英文请输入EN:”)
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)
pre_js = response.read().decode(‘utf-8’)
a = pre_js.split(‘[[’)
b = a[1].split(‘]]’)
c = b[0]
j = json.loads©
print(j[‘tgt’])
有兴趣的小伙伴可以多开发几种其他的语种,都是支持的,就是语种代号我没去弄。
可以做成一个语种下拉框,就好。
现在能在网上找到很多很多的学习资源,有免费的也有收费的,当我拿到1套比较全的学习资源之前,我并没着急去看第1节,我而是去审视这套资源是否值得学习,有时候也会去问一些学长的意见,如果可以之后,我会对这套学习资源做1个学习计划,我的学习计划主要包括规划图和学习进度表。
分享给大家这份我薅到的免费视频资料,质量还不错,大家可以跟着学习
网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!