有道爬虫添加User-Agent后不能翻译
我刚开始跟着小甲鱼做,没有添加User-Agent的时候可以翻译,添加了User-Agent之后,一直提示“ 您的请求来源非法,商业用途使用请关注有道翻译API官方网站“有道智云”: http:\/\/ai.youdao.com” 本帖最后由 Twilight6 于 2020-8-19 23:49 编辑不懂你的代码是什么样的,按正常来说如果没加 UA 那更不可能翻译成功吧
参考下这个代码吧:
import urllib.request
import urllib.parse
import json
import time
while True:
content=input('请输入要翻译的内容(如果结束请输入Esc):')
if content=='Esc':
break
headers={}
headers['User-Agent']='Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/70.0.3538.25 Safari/537.36 Core/1.70.3706.400 SLBrowser/10.0.4040.400'
url='http://fanyi.youdao.com/translate?smartresult=dict&smartresult=rule'
data={'i':content,
'from':'AUTO',
'to':'AUTO',
'smartresult':'dict',
'client':'fanyideskweb',
'salt':'15966771704905',
'sign': '8634c91db8413ef4cfbe684fd030d518',
'ts': '1596677170490',
'bv': 'd16528ec6ead722121051f646932f6ab',
'doctype': 'json',
'version': '2.1',
'keyfrom': 'fanyi.web',
'action':'FY_BY_REALTlME'}
data=urllib.parse.urlencode(data).encode('utf-8')
req = urllib.request.Request(url,data=data,headers=headers)
response=urllib.request.urlopen(req)
html=response.read().decode('utf-8')
target=json.loads(html)
target=target['translateResult']['tgt']
print(content+' 翻译为:'+target)
time.sleep(1)
Twilight6 发表于 2020-8-19 23:48
不懂你的代码是什么样的,按正常来说如果没加 UA 那更不可能翻译成功吧
参考下这个代码吧:
我是照着小甲鱼之前的代码敲的,已经可以翻译成功了,但是添加User-Agent之后就一直提示商业用途
req = urllib.request.Request(url,data=data,headers=headers)
我的是req = urllib.request.Request(url,data,head),上面已经定义好参数了
req=urllib.request.Request(url,data)
req.add_header('User-Agent','Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/83.0.4103.116 Safari/537.36' )
response = urllib.request.urlopen(req)
Hyg123456 发表于 2020-8-19 23:55
我是照着小甲鱼之前的代码敲的,已经可以翻译成功了,但是添加User-Agent之后就一直提示商业用途
req =...
发完整代码 Twilight6 发表于 2020-8-19 23:55
发完整代码
能翻译了,昨晚不行,今天可以了{:10_261:}{:10_247:} Hyg123456 发表于 2020-8-20 13:51
能翻译了,昨晚不行,今天可以了
问题解决了的话,就设置下最佳答案吧~
页:
[1]